Add Q15 FIR filter code.

fsk9600
Rob Riggs 2019-06-08 22:34:53 -05:00
rodzic 741bd802dd
commit 4ce17e7d53
1 zmienionych plików z 50 dodań i 2 usunięć

Wyświetl plik

@ -1,4 +1,4 @@
// Copyright 2015 Rob Riggs <rob@mobilinkd.com>
// Copyright 2015-2019 Rob Riggs <rob@mobilinkd.com>
// All rights reserved.
#ifndef MOBILINKD__TNC__FIR_FILTER_H_
@ -74,7 +74,7 @@ struct FirFilter {
float* operator()(int16_t* input) // __attribute__((section(".bss2")))
{
for (size_t i = 0; i != BLOCK_SIZE; i++) {
filter_input[i] = (float(input[i]) - vgnd_) * audio::i_vgnd;
filter_input[i] = float(input[i]);
}
arm_fir_f32(&instance, filter_input, filter_output, BLOCK_SIZE);
return filter_output;
@ -85,6 +85,54 @@ struct FirFilter {
arm_fir_f32(&instance, input, filter_output, BLOCK_SIZE);
return filter_output;
}
float operator()(float input) // __attribute__((section(".bss2")))
{
arm_fir_f32(&instance, &input, filter_output, 1);
return *filter_output;
}
};
template <size_t BLOCK_SIZE, size_t FILTER_SIZE>
struct Q15FirFilter {
const q15_t* filter_taps{nullptr};
q15_t filter_state[BLOCK_SIZE + FILTER_SIZE - 1];
q15_t filter_input[BLOCK_SIZE];
q15_t filter_output[BLOCK_SIZE];
q15_t vgnd_{0};
q15_t i_vgnd_{0};
arm_fir_instance_q15 instance{};
Q15FirFilter()
{}
Q15FirFilter(const q15_t* taps)
: filter_taps(taps)
{
init(taps);
}
void init(const q15_t* taps)
{
vgnd_ = audio::virtual_ground;
filter_taps = taps;
arm_fir_init_q15(&instance, FILTER_SIZE, const_cast<q15_t*>(filter_taps), // WTF ARM?!?
filter_state, BLOCK_SIZE);
}
// ADC input
q15_t* operator()(q15_t* input) // __attribute__((section(".bss2")))
{
arm_fir_fast_q15(&instance, input, filter_output, BLOCK_SIZE);
return filter_output;
}
// LPF input
q15_t* filter(q15_t* input) // __attribute__((section(".bss2")))
{
arm_fir_fast_q15(&instance, input, filter_output, BLOCK_SIZE);
return filter_output;
}
};
}} // mobilinkd::tnc