-
Notifications
You must be signed in to change notification settings - Fork 25
/
EMGFilters.h
76 lines (69 loc) · 3.2 KB
/
EMGFilters.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*
* Copyright 2017, OYMotion Inc.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
* THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
*/
#ifndef _EMGFILTERS_H
#define _EMGFILTERS_H
enum NOTCH_FREQUENCY { NOTCH_FREQ_50HZ = 50, NOTCH_FREQ_60HZ = 60 };
enum SAMPLE_FREQUENCY { SAMPLE_FREQ_500HZ = 500, SAMPLE_FREQ_1000HZ = 1000 };
// \brief EMGFilter provides an anti-hum notch filter to filter out 50HZ or
// 60HZ power line noise, a lowpass filter to filter out signals above
// 150HZ, and a highpass filter to filter out noise below 20HZ;
// You can turn on or off these filters by the init function.
// \remark Input frequencies of 500HZ and 1000HZ are supported only!
class EMGFilters {
public:
// \brief Initializes the filter.
// \param sampleFreq only supports SAMPLE_FREQ_500HZ &
// SAMPLE_FREQ_1000HZ.
// \param notchFreq only supports NOTCH_FREQ_50HZ & NOTCH_FREQ_60HZ.
// \param enableNotchFilter enables the notch filter. True by default.
// \param enableLowpassFilter enables the lowpass filter. True by
// default.
// \param enableHighpassFilter enables the highpass filter. True by
// default
// \remark The filter won't work and just bypass input if sampleFreq or
// notchFreq isn't specified properly.
void init(SAMPLE_FREQUENCY sampleFreq,
NOTCH_FREQUENCY notchFreq,
bool enableNotchFilter = true,
bool enableLowpassFilter = true,
bool enableHighpassFilter = true);
// \brief Called in the loop, input read analog value to get filtered
// value
int update(int inputValue);
private:
SAMPLE_FREQUENCY m_sampleFreq;
NOTCH_FREQUENCY m_notchFreq;
bool m_bypassEnabled;
bool m_notchFilterEnabled;
bool m_lowpassFilterEnabled;
bool m_highpassFilterEnabled;
};
#endif