From c9a56e222339da4952b0f23be7b81905e7c11edf Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Wed, 8 Aug 2012 11:03:55 +1000 Subject: [PATCH] Filter: fixed a off-by-one DerivativeFilter bug many thanks to Jon Challinger for noticing this! --- libraries/Filter/DerivativeFilter.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/libraries/Filter/DerivativeFilter.cpp b/libraries/Filter/DerivativeFilter.cpp index 817bd0a64f..8a09aea938 100644 --- a/libraries/Filter/DerivativeFilter.cpp +++ b/libraries/Filter/DerivativeFilter.cpp @@ -33,8 +33,8 @@ float DerivativeFilter::slope(void) // use f() to make the code match the maths a bit better. Note // that unlike an average filter, we care about the order of the elements - #define f(i) FilterWithBuffer::samples[(((FilterWithBuffer::sample_index-1)+i)+3*FILTER_SIZE/2) % FILTER_SIZE] - #define x(i) _timestamps[(((FilterWithBuffer::sample_index-1)+i)+3*FILTER_SIZE/2) % FILTER_SIZE] + #define f(i) FilterWithBuffer::samples[(((FilterWithBuffer::sample_index-1)+i+1)+3*FILTER_SIZE/2) % FILTER_SIZE] + #define x(i) _timestamps[(((FilterWithBuffer::sample_index-1)+i+1)+3*FILTER_SIZE/2) % FILTER_SIZE] if (_timestamps[FILTER_SIZE-1] == _timestamps[FILTER_SIZE-2]) { // we haven't filled the buffer yet - assume zero derivative @@ -98,5 +98,9 @@ template void DerivativeFilter::update(float sample, uint32_t timestamp template float DerivativeFilter::slope(void); template void DerivativeFilter::reset(void); +template void DerivativeFilter::update(float sample, uint32_t timestamp); +template float DerivativeFilter::slope(void); +template void DerivativeFilter::reset(void); +