aboutsummaryrefslogtreecommitdiffstats
path: root/examples/6_iir_test.cpp
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;
}