-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmavg.c
43 lines (29 loc) · 966 Bytes
/
mavg.c
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
#include "rtl_rfm.h"
#include "mavg.h"
bool mavg_init(Mavg *filter, uint16_t newsize) {
filter->size = newsize;
filter->data = malloc(sizeof(int16_t) * newsize);
filter->index = 0;
filter->count = 0;
filter->counthold = 0;
filter->hold = false;
for (int i = 0; i < newsize; i++) filter->data[i] = 0;
return true;
}
bool mavg_cleanup(Mavg *filter) {
free(filter->data);
return true;
}
int32_t mavg_count(Mavg *filter, int16_t sample) {
filter->index = (filter->index + 1) % filter->size;
filter->count += sample - filter->data[filter->index];
filter->data[filter->index] = sample;
return filter->count;
}
int16_t mavg_hipass(Mavg *filter, int16_t sample) {
if (!filter->hold) filter->counthold = mavg_count(filter, sample);
return sample - (filter->counthold / filter->size);
}
int16_t mavg_lopass(Mavg *filter, int16_t sample) {
return mavg_count(filter, sample) / filter->size;
}