annotate dsp/phasevocoder/PhaseVocoder.cpp @ 84:e5907ae6de17

* Add GPL and README; some tidying
author Chris Cannam
date Mon, 13 Dec 2010 14:55:28 +0000
parents 6cb2b3cd5356
children f3c69325cca2
rev   line source
cannam@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
cannam@0 2
cannam@0 3 /*
cannam@0 4 QM DSP Library
cannam@0 5
cannam@0 6 Centre for Digital Music, Queen Mary, University of London.
Chris@84 7 This file 2005-2006 Christian Landone.
Chris@84 8
Chris@84 9 This program is free software; you can redistribute it and/or
Chris@84 10 modify it under the terms of the GNU General Public License as
Chris@84 11 published by the Free Software Foundation; either version 2 of the
Chris@84 12 License, or (at your option) any later version. See the file
Chris@84 13 COPYING included with this distribution for more information.
cannam@0 14 */
cannam@0 15
cannam@0 16 #include "PhaseVocoder.h"
cannam@0 17 #include "dsp/transforms/FFT.h"
cannam@0 18 #include <math.h>
cannam@0 19
cannam@0 20 //////////////////////////////////////////////////////////////////////
cannam@0 21 // Construction/Destruction
cannam@0 22 //////////////////////////////////////////////////////////////////////
cannam@0 23
cannam@64 24 PhaseVocoder::PhaseVocoder(unsigned int n) :
cannam@64 25 m_n(n)
cannam@0 26 {
cannam@64 27 m_fft = new FFTReal(m_n);
cannam@64 28 m_realOut = new double[m_n];
cannam@64 29 m_imagOut = new double[m_n];
cannam@0 30 }
cannam@0 31
cannam@0 32 PhaseVocoder::~PhaseVocoder()
cannam@0 33 {
cannam@64 34 delete [] m_realOut;
cannam@64 35 delete [] m_imagOut;
cannam@64 36 delete m_fft;
cannam@0 37 }
cannam@0 38
cannam@0 39 void PhaseVocoder::FFTShift(unsigned int size, double *src)
cannam@0 40 {
cannam@55 41 const int hs = size/2;
cannam@55 42 for (int i = 0; i < hs; ++i) {
cannam@55 43 double tmp = src[i];
cannam@55 44 src[i] = src[i + hs];
cannam@55 45 src[i + hs] = tmp;
cannam@0 46 }
cannam@0 47 }
cannam@0 48
cannam@64 49 void PhaseVocoder::process(double *src, double *mag, double *theta)
cannam@0 50 {
cannam@64 51 FFTShift( m_n, src);
cannam@64 52
cannam@64 53 m_fft->process(0, src, m_realOut, m_imagOut);
cannam@0 54
cannam@64 55 getMagnitude( m_n/2, mag, m_realOut, m_imagOut);
cannam@64 56 getPhase( m_n/2, theta, m_realOut, m_imagOut);
cannam@0 57 }
cannam@0 58
cannam@0 59 void PhaseVocoder::getMagnitude(unsigned int size, double *mag, double *real, double *imag)
cannam@0 60 {
cannam@0 61 unsigned int j;
cannam@0 62
cannam@0 63 for( j = 0; j < size; j++)
cannam@0 64 {
cannam@0 65 mag[ j ] = sqrt( real[ j ] * real[ j ] + imag[ j ] * imag[ j ]);
cannam@0 66 }
cannam@0 67 }
cannam@0 68
cannam@0 69 void PhaseVocoder::getPhase(unsigned int size, double *theta, double *real, double *imag)
cannam@0 70 {
cannam@0 71 unsigned int k;
cannam@0 72
cannam@0 73 // Phase Angle "matlab" style
cannam@0 74 //Watch out for quadrant mapping !!!
cannam@0 75 for( k = 0; k < size; k++)
cannam@0 76 {
cannam@0 77 theta[ k ] = atan2( -imag[ k ], real[ k ]);
cannam@0 78 }
cannam@0 79 }