annotate dsp/signalconditioning/Filter.h @ 153:715f779d0b4f

Some docs; remove FiltFiltConfig as it's the same as FilterConfig
author Chris Cannam
date Mon, 21 Oct 2013 11:59:57 +0100
parents e5907ae6de17
children ca658c7215a9
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 #ifndef FILTER_H
cannam@0 17 #define FILTER_H
cannam@0 18
cannam@0 19 #ifndef NULL
cannam@0 20 #define NULL 0
cannam@0 21 #endif
cannam@0 22
Chris@153 23 /**
Chris@153 24 * Filter specification. For a filter of order ord, the ACoeffs and
Chris@153 25 * BCoeffs arrays must point to ord+1 values each. ACoeffs provides
Chris@153 26 * the denominator and BCoeffs the numerator coefficients of the
Chris@153 27 * filter.
Chris@153 28 */
cannam@0 29 struct FilterConfig{
cannam@0 30 unsigned int ord;
cannam@0 31 double* ACoeffs;
cannam@0 32 double* BCoeffs;
cannam@0 33 };
cannam@0 34
Chris@153 35 /**
Chris@153 36 * Digital filter specified through FilterConfig structure.
Chris@153 37 */
cannam@0 38 class Filter
cannam@0 39 {
cannam@0 40 public:
cannam@0 41 Filter( FilterConfig Config );
cannam@0 42 virtual ~Filter();
cannam@0 43
cannam@0 44 void reset();
cannam@0 45
cannam@0 46 void process( double *src, double *dst, unsigned int length );
cannam@0 47
cannam@0 48 private:
cannam@0 49 void initialise( FilterConfig Config );
cannam@0 50 void deInitialise();
cannam@0 51
cannam@0 52 unsigned int m_ord;
cannam@0 53
cannam@0 54 double* m_inBuffer;
cannam@0 55 double* m_outBuffer;
cannam@0 56
cannam@0 57 double* m_ACoeffs;
cannam@0 58 double* m_BCoeffs;
cannam@0 59 };
cannam@0 60
cannam@0 61 #endif