Blender V2.61 - r43446
|
00001 /* 00002 * ***** BEGIN GPL LICENSE BLOCK ***** 00003 * 00004 * Copyright 2009-2011 Jörg Hermann Müller 00005 * 00006 * This file is part of AudaSpace. 00007 * 00008 * Audaspace is free software; you can redistribute it and/or modify 00009 * it under the terms of the GNU General Public License as published by 00010 * the Free Software Foundation; either version 2 of the License, or 00011 * (at your option) any later version. 00012 * 00013 * AudaSpace is distributed in the hope that it will be useful, 00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00016 * GNU General Public License for more details. 00017 * 00018 * You should have received a copy of the GNU General Public License 00019 * along with Audaspace; if not, write to the Free Software Foundation, 00020 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 00021 * 00022 * ***** END GPL LICENSE BLOCK ***** 00023 */ 00024 00030 #ifndef AUD_IIRFILTERREADER 00031 #define AUD_IIRFILTERREADER 00032 00033 #include "AUD_BaseIIRFilterReader.h" 00034 00035 #include <vector> 00036 00040 class AUD_IIRFilterReader : public AUD_BaseIIRFilterReader 00041 { 00042 private: 00046 std::vector<float> m_a; 00047 00051 std::vector<float> m_b; 00052 00053 // hide copy constructor and operator= 00054 AUD_IIRFilterReader(const AUD_IIRFilterReader&); 00055 AUD_IIRFilterReader& operator=(const AUD_IIRFilterReader&); 00056 00057 public: 00064 AUD_IIRFilterReader(AUD_Reference<AUD_IReader> reader, const std::vector<float>& b, 00065 const std::vector<float>& a); 00066 00067 virtual sample_t filter(); 00068 00069 void setCoefficients(const std::vector<float>& b, 00070 const std::vector<float>& a); 00071 }; 00072 00073 #endif //AUD_IIRFILTERREADER