c@225: /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ c@225: c@225: /* c@225: QM DSP Library c@225: c@225: Centre for Digital Music, Queen Mary, University of London. c@225: This file copyright 2005-2006 Christian Landone. c@225: All rights reserved. c@225: */ c@225: c@225: #include "Filter.h" c@225: c@225: ////////////////////////////////////////////////////////////////////// c@225: // Construction/Destruction c@225: ////////////////////////////////////////////////////////////////////// c@225: c@225: Filter::Filter( FilterConfig Config ) c@225: { c@225: m_ord = 0; c@225: m_outBuffer = NULL; c@225: m_inBuffer = NULL; c@225: c@225: initialise( Config ); c@225: } c@225: c@225: Filter::~Filter() c@225: { c@225: deInitialise(); c@225: } c@225: c@225: void Filter::initialise( FilterConfig Config ) c@225: { c@225: m_ord = Config.ord; c@225: m_ACoeffs = Config.ACoeffs; c@225: m_BCoeffs = Config.BCoeffs; c@225: c@225: m_inBuffer = new double[ m_ord + 1 ]; c@225: m_outBuffer = new double[ m_ord + 1 ]; c@225: c@225: reset(); c@225: } c@225: c@225: void Filter::deInitialise() c@225: { c@225: delete[] m_inBuffer; c@225: delete[] m_outBuffer; c@225: } c@225: c@225: void Filter::reset() c@225: { c@225: for( unsigned int i = 0; i < m_ord+1; i++ ){ m_inBuffer[ i ] = 0.0; } c@225: for(unsigned int i = 0; i < m_ord+1; i++ ){ m_outBuffer[ i ] = 0.0; } c@225: } c@225: c@225: void Filter::process( double *src, double *dst, unsigned int length ) c@225: { c@225: unsigned int SP,i,j; c@225: c@225: double xin,xout; c@225: c@225: for (SP=0;SP