From 416bd737074a287ea47106c73ea6bcfde40a75a8 Mon Sep 17 00:00:00 2001 From: John Glover Date: Fri, 24 Jun 2011 18:17:23 +0100 Subject: Change to using distutils. Currently only builds the simplsndobj module --- src/sndobj/PVA.h | 66 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) create mode 100644 src/sndobj/PVA.h (limited to 'src/sndobj/PVA.h') diff --git a/src/sndobj/PVA.h b/src/sndobj/PVA.h new file mode 100644 index 0000000..0826f99 --- /dev/null +++ b/src/sndobj/PVA.h @@ -0,0 +1,66 @@ + +//////////////////////////////////////////////////////////////////////// +// This file is part of the SndObj library +// +// 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. +// +// You should have received a copy of the GNU General Public License +// along with this program; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// Copyright (c)Victor Lazzarini, 1997-2004 +// See License.txt for a disclaimer of all warranties +// and licensing information + +////////////////////////////////////////////////////// +// PVA.h: Phase Vocoder Analysis Class +// +// Victor Lazzarini, 2003 +// +///////////////////////////////////////////////////////// + +#ifndef _PVA_H +#define _PVA_H +#include "FFT.h" + +class PVA : public FFT { + + protected: + + int m_rotcount; // rotation counter + double m_factor; // conversion factor + double* m_phases; + + private: + + void inline pvanalysis(double* signal); + + public: + + PVA(); + PVA(Table* window, SndObj* input, double scale=1.f, + int fftsize=DEF_FFTSIZE, int hopsize=DEF_VECSIZE, double sr=DEF_SR); + + ~PVA(); + double Outphases(int pos){ return m_phases[pos]; } // reads phase output. + int Set(char* mess, double value); + void SetFFTSize(int fftsize); + void SetHopSize(int hopsize); + short DoProcess(); + +}; + +#endif + + + + + -- cgit v1.2.3