svn merge -r39781:39792 https://svn.blender.org/svnroot/bf-blender/trunk/blender...
[blender-staging.git] / intern / audaspace / FX / AUD_BaseIIRFilterReader.cpp
1 /*
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * Copyright 2009-2011 Jörg Hermann Müller
7  *
8  * This file is part of AudaSpace.
9  *
10  * Audaspace is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * AudaSpace is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License
21  * along with Audaspace; if not, write to the Free Software Foundation,
22  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file audaspace/FX/AUD_BaseIIRFilterReader.cpp
28  *  \ingroup audfx
29  */
30
31
32 #include "AUD_BaseIIRFilterReader.h"
33
34 #include <cstring>
35
36 #define CC m_specs.channels + m_channel
37
38 AUD_BaseIIRFilterReader::AUD_BaseIIRFilterReader(AUD_Reference<AUD_IReader> reader, int in,
39                                                                                                  int out) :
40                 AUD_EffectReader(reader),
41                 m_specs(reader->getSpecs()),
42                 m_xlen(in), m_ylen(out),
43                 m_xpos(0), m_ypos(0), m_channel(0)
44 {
45         m_x = new sample_t[m_xlen * m_specs.channels];
46         m_y = new sample_t[m_ylen * m_specs.channels];
47
48         memset(m_x, 0, sizeof(sample_t) * m_xlen * m_specs.channels);
49         memset(m_y, 0, sizeof(sample_t) * m_ylen * m_specs.channels);
50 }
51
52 AUD_BaseIIRFilterReader::~AUD_BaseIIRFilterReader()
53 {
54         delete[] m_x;
55         delete[] m_y;
56 }
57
58 void AUD_BaseIIRFilterReader::setLengths(int in, int out)
59 {
60         if(in != m_xlen)
61         {
62                 sample_t* xn = new sample_t[in * m_specs.channels];
63                 memset(xn, 0, sizeof(sample_t) * in * m_specs.channels);
64
65                 for(m_channel = 0; m_channel < m_specs.channels; m_channel++)
66                 {
67                         for(int i = 1; i <= in && i <= m_xlen; i++)
68                         {
69                                 xn[(in - i) * CC] = x(-i);
70                         }
71                 }
72
73                 delete[] m_x;
74                 m_x = xn;
75                 m_xpos = 0;
76                 m_xlen = in;
77         }
78
79         if(out != m_ylen)
80         {
81                 sample_t* yn = new sample_t[out * m_specs.channels];
82                 memset(yn, 0, sizeof(sample_t) * out * m_specs.channels);
83
84                 for(m_channel = 0; m_channel < m_specs.channels; m_channel++)
85                 {
86                         for(int i = 1; i <= out && i <= m_ylen; i++)
87                         {
88                                 yn[(out - i) * CC] = y(-i);
89                         }
90                 }
91
92                 delete[] m_y;
93                 m_y = yn;
94                 m_ypos = 0;
95                 m_ylen = out;
96         }
97 }
98
99 void AUD_BaseIIRFilterReader::read(int& length, bool& eos, sample_t* buffer)
100 {
101         AUD_Specs specs = m_reader->getSpecs();
102         if(specs.channels != m_specs.channels)
103         {
104                 m_specs.channels = specs.channels;
105
106                 delete[] m_x;
107                 delete[] m_y;
108
109                 m_x = new sample_t[m_xlen * m_specs.channels];
110                 m_y = new sample_t[m_ylen * m_specs.channels];
111
112                 memset(m_x, 0, sizeof(sample_t) * m_xlen * m_specs.channels);
113                 memset(m_y, 0, sizeof(sample_t) * m_ylen * m_specs.channels);
114         }
115
116         if(specs.rate != m_specs.rate)
117         {
118                 m_specs = specs;
119                 sampleRateChanged(m_specs.rate);
120         }
121
122         m_reader->read(length, eos, buffer);
123
124         for(m_channel = 0; m_channel < m_specs.channels; m_channel++)
125         {
126                 for(int i = 0; i < length; i++)
127                 {
128                         m_x[m_xpos * CC] = buffer[i * CC];
129                         m_y[m_ypos * CC] = buffer[i * CC] = filter();
130
131                         m_xpos = (m_xpos + 1) % m_xlen;
132                         m_ypos = (m_ypos + 1) % m_ylen;
133                 }
134         }
135 }
136
137 void AUD_BaseIIRFilterReader::sampleRateChanged(AUD_SampleRate rate)
138 {
139 }