2007-11-06 21:41:16 +00:00
|
|
|
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
Rubber Band
|
|
|
|
|
An audio time-stretching and pitch-shifting library.
|
2010-03-24 09:44:51 +00:00
|
|
|
Copyright 2007-2010 Chris Cannam.
|
2007-11-06 21:41:16 +00:00
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
*/
|
|
|
|
|
|
2009-09-17 13:01:21 +00:00
|
|
|
#ifndef _AUDIO_CURVE_CALCULATOR_H_
|
|
|
|
|
#define _AUDIO_CURVE_CALCULATOR_H_
|
2007-11-06 21:41:16 +00:00
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
|
2009-09-17 13:01:21 +00:00
|
|
|
|
|
|
|
|
#include "system/sysutils.h"
|
2008-05-22 16:54:27 +00:00
|
|
|
|
2007-11-06 21:41:16 +00:00
|
|
|
namespace RubberBand
|
|
|
|
|
{
|
|
|
|
|
|
2009-09-17 13:01:21 +00:00
|
|
|
class AudioCurveCalculator
|
2007-11-06 21:41:16 +00:00
|
|
|
{
|
|
|
|
|
public:
|
2010-03-24 09:44:51 +00:00
|
|
|
struct Parameters {
|
2010-05-16 10:44:38 +01:00
|
|
|
Parameters(int _sampleRate, int _fftSize) :
|
2010-03-24 09:44:51 +00:00
|
|
|
sampleRate(_sampleRate),
|
2010-05-16 10:44:38 +01:00
|
|
|
fftSize(_fftSize)
|
2010-03-24 09:44:51 +00:00
|
|
|
{ }
|
|
|
|
|
int sampleRate;
|
2010-05-16 10:44:38 +01:00
|
|
|
int fftSize;
|
2010-03-24 09:44:51 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
AudioCurveCalculator(Parameters parameters);
|
2009-09-17 13:01:21 +00:00
|
|
|
virtual ~AudioCurveCalculator();
|
|
|
|
|
|
2010-03-24 09:44:51 +00:00
|
|
|
int getSampleRate() const { return m_sampleRate; }
|
2010-05-16 10:44:38 +01:00
|
|
|
int getFftSize() const { return m_fftSize; }
|
2007-11-06 21:41:16 +00:00
|
|
|
|
2010-03-24 09:44:51 +00:00
|
|
|
virtual void setSampleRate(int newRate);
|
2010-05-16 10:44:38 +01:00
|
|
|
virtual void setFftSize(int newSize);
|
2010-03-24 09:44:51 +00:00
|
|
|
|
|
|
|
|
Parameters getParameters() const {
|
2010-05-16 10:44:38 +01:00
|
|
|
return Parameters(m_sampleRate, m_fftSize);
|
2010-03-24 09:44:51 +00:00
|
|
|
}
|
|
|
|
|
void setParameters(Parameters p) {
|
|
|
|
|
setSampleRate(p.sampleRate);
|
2010-05-16 10:44:38 +01:00
|
|
|
setFftSize(p.fftSize);
|
2010-03-24 09:44:51 +00:00
|
|
|
}
|
2009-09-17 13:01:21 +00:00
|
|
|
|
|
|
|
|
// You may not mix calls to the various process functions on a
|
|
|
|
|
// given instance
|
|
|
|
|
|
|
|
|
|
|
2010-03-24 09:44:51 +00:00
|
|
|
virtual float processFloat(const float *R__ mag, int increment) = 0;
|
|
|
|
|
virtual double processDouble(const double *R__ mag, int increment) = 0;
|
2009-09-17 13:01:21 +00:00
|
|
|
|
2007-11-06 21:41:16 +00:00
|
|
|
virtual void reset() = 0;
|
|
|
|
|
|
2010-03-24 09:44:51 +00:00
|
|
|
virtual const char *getUnit() const { return ""; }
|
|
|
|
|
|
2007-11-06 21:41:16 +00:00
|
|
|
protected:
|
2010-03-24 09:44:51 +00:00
|
|
|
int m_sampleRate;
|
2010-05-16 10:44:38 +01:00
|
|
|
int m_fftSize;
|
2010-03-24 09:44:51 +00:00
|
|
|
int m_lastPerceivedBin;
|
|
|
|
|
void recalculateLastPerceivedBin();
|
2007-11-06 21:41:16 +00:00
|
|
|
};
|
|
|
|
|
|
2010-03-24 09:44:51 +00:00
|
|
|
|
2007-11-06 21:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|