/* FFTease - A set of Live Spectral Processors Originally written by Eric Lyon and Christopher Penrose for the Max/MSP platform Copyright (c)Thomas Grill (xovo@gmx.net) For information on usage and redistribution, and for a DISCLAIMER OF ALL WARRANTIES, see the file, "license.txt," in this distribution. */ #ifndef __FFTEASE_H #define __FFTEASE_H #define FFTEASE_VERSION "0.0.0" #define FLEXT_ATTRIBUTES 1 #include <flext.h> #if !defined(FLEXT_VERSION) || (FLEXT_VERSION < 401) #error You need at least flext version 0.4.1 #endif #include "pv.h" // lazy me #define F float #define D double #define I int #define L long #define C char #define V void #define BL bool #define S t_sample class fftease: public flext_dsp { FLEXT_HEADER(fftease,flext_dsp) public: fftease(I mult,I flags); virtual ~fftease(); static F FromdB(F v) { return pow(10.,v*.05); } inline I get_N() const { return _N; } inline F get_Fund() const { return smprt/_N; } protected: virtual BL Init(); virtual V Exit(); virtual V m_dsp(I n,S *const *in,S *const *out); virtual V m_signal(I n,S *const *in,S *const *out); virtual V Set(); virtual V Clear(); virtual V Delete(); virtual V Transform(I _N,S *const *in) = 0; V Mult(I n) { _mult = n; MakeVar(); } inline I Mult() const { return _mult; } F *_input1,*_input2; F *_buffer1,*_buffer2; F *_channel1,*_channel2; F *_output; F *_trigland; I *_bitshuffle; F *_Wanal,*_Wsyn,*_Hwin; F *_c_lastphase_in1,*_c_lastphase_in2,*_c_lastphase_out; F _c_factor_in; I _inCount; enum { F_STEREO = 0x01, F_BALANCED = 0x02, F_BITSHUFFLE = 0x04, F_RMS = 0x08, F_NOSPEC = 0x10,F_SPECRES = 0x20,F_PHCONV = 0x40, F_NOAMP1 = 0x100, F_NOPH1 = 0x200, F_NOAMP2 = 0x400, F_NOPH2 = 0x800 }; I _flags; F _rms; private: V MakeVar() { _N = Blocksize()*_mult; } I blsz; F smprt; I _mult,_N; }; #endif