2016-09-10 13:03:27 -07:00
|
|
|
/*
|
|
|
|
* @file biquad.cpp
|
|
|
|
*
|
|
|
|
* @date Sep 10, 2016
|
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2016
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "biquad.h"
|
|
|
|
|
|
|
|
Biquad::Biquad() {
|
2016-09-17 12:02:55 -07:00
|
|
|
a0 = a1 = a2 = b1 = b2;
|
|
|
|
z1 = z2 = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Biquad::initValue(float input DECLARE_ENGINE_PARAMETER_S) {
|
2016-09-10 13:03:27 -07:00
|
|
|
a0 = 0.0000024635293743901;
|
|
|
|
a1 = 0.00000492705874878021;
|
|
|
|
a2 = 0.0000024635293743901;
|
|
|
|
b1 = -1.9968534854;
|
|
|
|
b2 = 0.9968633396;
|
|
|
|
|
2016-09-17 12:02:55 -07:00
|
|
|
z1 = input * (1 - a0);
|
2016-09-10 19:03:38 -07:00
|
|
|
z2 = input * (1 - a0 - a1 + b1);
|
|
|
|
}
|
|
|
|
|
2016-09-10 13:03:27 -07:00
|
|
|
float Biquad::getValue(float input) {
|
|
|
|
float result = input * a0 + z1;
|
|
|
|
z1 = input * a1 + z2 - b1 * result;
|
|
|
|
z2 = input * a2 - b2 * result;
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|