blob: e0b266d11121bc76f4a59fb61ff5755be340825f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/**
* 6_iir_test.cpp
* Written by Clyne Sullivan.
*
* Implements a simple infinite impulse response (IIR) filter using an alpha
* parameter.
* To build upon this example, try setting `alpha` with a parameter knob:
* alpha = param1() / 4095.0
*/
Sample* process_data(Samples samples)
{
constexpr float alpha = 0.7;
static Sample prev = 2048;
samples[0] = (1 - alpha) * samples[0] + alpha * prev;
for (unsigned int i = 1; i < SIZE; i++)
samples[i] = (1 - alpha) * samples[i] + alpha * samples[i - 1];
prev = samples[SIZE - 1];
return samples;
}
|