From 061ddf7a3f647adcae4520f416e8cca0afcc186e Mon Sep 17 00:00:00 2001 From: Andy Piper Date: Sat, 12 Mar 2022 14:46:24 +0000 Subject: [PATCH] AP_HAL_SITL: save a sliding window of frequency bins --- libraries/AP_HAL_SITL/DSP.cpp | 10 +++++----- libraries/AP_HAL_SITL/DSP.h | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/libraries/AP_HAL_SITL/DSP.cpp b/libraries/AP_HAL_SITL/DSP.cpp index b176c0c14b..c67223bfe7 100644 --- a/libraries/AP_HAL_SITL/DSP.cpp +++ b/libraries/AP_HAL_SITL/DSP.cpp @@ -35,9 +35,9 @@ extern const AP_HAL::HAL& hal; // important as frequency resolution. Referred to as [Heinz] throughout the code. // initialize the FFT state machine -AP_HAL::DSP::FFTWindowState* DSP::fft_init(uint16_t window_size, uint16_t sample_rate) +AP_HAL::DSP::FFTWindowState* DSP::fft_init(uint16_t window_size, uint16_t sample_rate, uint8_t sliding_window_size) { - DSP::FFTWindowStateSITL* fft = new DSP::FFTWindowStateSITL(window_size, sample_rate); + DSP::FFTWindowStateSITL* fft = new DSP::FFTWindowStateSITL(window_size, sample_rate, sliding_window_size); if (fft == nullptr || fft->_hanning_window == nullptr || fft->_rfft_data == nullptr || fft->_freq_bins == nullptr || fft->_derivative_freq_bins == nullptr) { delete fft; return nullptr; @@ -61,8 +61,8 @@ uint16_t DSP::fft_analyse(AP_HAL::DSP::FFTWindowState* state, uint16_t start_bin } // create an instance of the FFT state machine -DSP::FFTWindowStateSITL::FFTWindowStateSITL(uint16_t window_size, uint16_t sample_rate) - : AP_HAL::DSP::FFTWindowState::FFTWindowState(window_size, sample_rate) +DSP::FFTWindowStateSITL::FFTWindowStateSITL(uint16_t window_size, uint16_t sample_rate, uint8_t sliding_window_size) + : AP_HAL::DSP::FFTWindowState::FFTWindowState(window_size, sample_rate, sliding_window_size) { if (_freq_bins == nullptr || _hanning_window == nullptr || _rfft_data == nullptr || _derivative_freq_bins == nullptr) { GCS_SEND_TEXT(MAV_SEVERITY_WARNING, "Failed to allocate window for DSP"); @@ -91,7 +91,7 @@ void DSP::step_hanning(FFTWindowStateSITL* fft, FloatBuffer& samples, uint16_t a mult_f32(&fft->_freq_bins[0], &fft->_hanning_window[0], &fft->_freq_bins[0], fft->_window_size); } -// step 2: performm an in-place FFT on the windowed data +// step 2: perform an in-place FFT on the windowed data void DSP::step_fft(FFTWindowStateSITL* fft) { for (uint16_t i = 0; i < fft->_window_size; i++) { diff --git a/libraries/AP_HAL_SITL/DSP.h b/libraries/AP_HAL_SITL/DSP.h index 6d7421e31f..9813fe4bfe 100644 --- a/libraries/AP_HAL_SITL/DSP.h +++ b/libraries/AP_HAL_SITL/DSP.h @@ -27,7 +27,7 @@ typedef std::complex complexf; class HALSITL::DSP : public AP_HAL::DSP { public: // initialise an FFT instance - virtual FFTWindowState* fft_init(uint16_t window_size, uint16_t sample_rate) override; + virtual FFTWindowState* fft_init(uint16_t window_size, uint16_t sample_rate, uint8_t sliding_window_size) override; // start an FFT analysis with an ObjectBuffer virtual void fft_start(FFTWindowState* state, FloatBuffer& samples, uint16_t advance) override; // perform remaining steps of an FFT analysis @@ -38,7 +38,7 @@ public: friend class HALSITL::DSP; public: - FFTWindowStateSITL(uint16_t window_size, uint16_t sample_rate); + FFTWindowStateSITL(uint16_t window_size, uint16_t sample_rate, uint8_t sliding_window_size); virtual ~FFTWindowStateSITL(); private: