|
Blender
V2.59
|
00001 /* 00002 * $Id: AUD_IIRFilterReader.cpp 35141 2011-02-25 10:21:56Z jesterking $ 00003 * 00004 * ***** BEGIN GPL LICENSE BLOCK ***** 00005 * 00006 * Copyright 2009-2011 Jörg Hermann Müller 00007 * 00008 * This file is part of AudaSpace. 00009 * 00010 * Audaspace is free software; you can redistribute it and/or modify 00011 * it under the terms of the GNU General Public License as published by 00012 * the Free Software Foundation; either version 2 of the License, or 00013 * (at your option) any later version. 00014 * 00015 * AudaSpace is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 * GNU General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU General Public License 00021 * along with Audaspace; if not, write to the Free Software Foundation, 00022 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 00023 * 00024 * ***** END GPL LICENSE BLOCK ***** 00025 */ 00026 00032 #include "AUD_IIRFilterReader.h" 00033 00034 AUD_IIRFilterReader::AUD_IIRFilterReader(AUD_IReader* reader, 00035 std::vector<float> b, 00036 std::vector<float> a) : 00037 AUD_BaseIIRFilterReader(reader, b.size(), a.size()), m_a(a), m_b(b) 00038 { 00039 for(int i = 1; i < m_a.size(); i++) 00040 m_a[i] /= m_a[0]; 00041 for(int i = 0; i < m_b.size(); i++) 00042 m_b[i] /= m_a[0]; 00043 m_a[0] = 1; 00044 } 00045 00046 sample_t AUD_IIRFilterReader::filter() 00047 { 00048 sample_t out = 0; 00049 00050 for(int i = 1; i < m_a.size(); i++) 00051 out -= y(-i) * m_a[i]; 00052 for(int i = 0; i < m_b.size(); i++) 00053 out += x(-i) * m_b[i]; 00054 00055 return out; 00056 }