ref: 0ce98c7ac7ba66acaf504be9bb042796e12f2733
src/components/heartrate/Biquad.cpp
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
/* SPDX-License-Identifier: LGPL-3.0-or-later Original work Copyright (C) 2020 Daniel Thompson C++ port Copyright (C) 2021 Jean-François Milants */ #include "Biquad.h" using namespace Pinetime::Controllers; /** Original implementation from wasp-os : https://github.com/daniel-thompson/wasp-os/blob/master/wasp/ppg.py */ 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; } |