21 lines
380 B
C++
21 lines
380 B
C++
|
#include "Biquad.h"
|
||
|
|
||
|
using namespace Pinetime::Controllers;
|
||
|
|
||
|
Biquad::Biquad(float b0, float b1, float b2, float a1, float a2) : b0{b0}, b1{b1}, b2{b2}, a1{a1}, a2{a2} {
|
||
|
|
||
|
}
|
||
|
|
||
|
float Biquad::Step(float x) {
|
||
|
auto v1 = this->v1;
|
||
|
auto v2 = this->v2;
|
||
|
|
||
|
auto v = x - (a1 * v1) - (a2 * v2);
|
||
|
auto y = (b0 * v) + (b1 * v1) + (b2 * v2);
|
||
|
|
||
|
this->v2 = v1;
|
||
|
this->v1 = v;
|
||
|
|
||
|
return y;
|
||
|
}
|