-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathfft_filter.h
66 lines (57 loc) · 1.64 KB
/
fft_filter.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
// _ ___ _ _____ _ _
// / |/ _ \/ | |_ _| |__ (_)_ __ __ _ ___
// | | | | | | | | | '_ \| | '_ \ / _` / __|
// | | |_| | | | | | | | | | | | | (_| \__ \.
// |_|\___/|_| |_| |_| |_|_|_| |_|\__, |___/
// |___/
//
// Copyright (c) Jonathan P Dawson 2024
// filename: fft_filter.h
// description:
// License: MIT
//
#ifndef FFT_FILTER_H
#define FFT_FILTER_H
#include <stdint.h>
#include <cmath>
#include "fft.h"
static const uint16_t fft_size = 256;
static const uint16_t new_fft_size = fft_size/2;
struct s_filter_control
{
uint16_t start_bin;
uint16_t stop_bin;
int16_t fft_bin;
bool lower_sideband;
bool upper_sideband;
bool capture;
bool enable_auto_notch;
};
class fft_filter
{
int16_t last_input_real[fft_size/2u];
int16_t last_input_imag[fft_size/2u];
int16_t last_output_real[new_fft_size/2];
int16_t last_output_imag[new_fft_size/2];
int32_t window[fft_size];
void filter_block(int16_t sample_real[], int16_t sample_imag[], s_filter_control &filter_control, int16_t capture[]);
public:
fft_filter()
{
fft_initialise();
for (uint16_t i = 0; i < fft_size; i++) {
float multiplier = 0.5 * (1 - cosf(2*M_PI*i/fft_size));
window[i] = float2fixed(multiplier);
}
for (uint16_t i = 0; i < fft_size/2u; i++) {
last_input_real[i] = 0;
last_input_imag[i] = 0;
}
for (uint16_t i = 0; i < new_fft_size/2; i++) {
last_output_real[i] = 0;
last_output_imag[i] = 0;
}
}
void process_sample(int16_t sample_real[], int16_t sample_imag[], s_filter_control &filter_control, int16_t capture[]);
};
#endif