forked from vitotai/BrewPiLess
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFilterCascaded.h
58 lines (50 loc) · 1.97 KB
/
FilterCascaded.h
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/*
* Copyright 2012-2013 BrewPi/Elco Jacobs.
*
* This file is part of BrewPi.
*
* BrewPi is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* BrewPi is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with BrewPi. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include "Brewpi.h"
#include "TemperatureFormats.h"
#include "FilterFixed.h"
// Use 3 filter sections. This gives excellent filtering, without adding too much delay.
// For 3 sections the stop band attenuation is 3x the single section attenuation in dB.
// The delay is also tripled.
#define NUM_SECTIONS 3
class CascadedFilter{
public:
// CascadedFilter implements a filter that consists of multiple second order secions.
FixedFilter sections[NUM_SECTIONS];
public:
CascadedFilter();
~CascadedFilter() {}
void init(temperature val);
void setCoefficients(uint8_t bValue);
temperature add(temperature val); // adds a value and returns the most recent filter output
temperature_precise addDoublePrecision(temperature_precise val);
temperature readInput(void); // returns the most recent filter input
temperature readOutput(void){
return sections[NUM_SECTIONS-1].readOutput(); // return output of last section
}
temperature_precise readOutputDoublePrecision(void);
temperature_precise readPrevOutputDoublePrecision(void);
temperature detectPosPeak(void){
return sections[NUM_SECTIONS-1].detectPosPeak(); // detect peaks in last section
}
temperature detectNegPeak(void){
return sections[NUM_SECTIONS-1].detectNegPeak(); // detect peaks in last section
}
};