// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- /* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ // /// @file FilterWithBuffer.h /// @brief A filter with a buffer. /// This is implemented separately to the base Filter class to get around /// restrictions caused by the use of templates which makes different sizes essentially /// completely different classes #ifndef __FILTER_WITH_BUFFER_H__ #define __FILTER_WITH_BUFFER_H__ #include "FilterClass.h" template class FilterWithBuffer : public Filter { public: // constructor FilterWithBuffer(); // apply - Add a new raw value to the filter, retrieve the filtered result T apply(T sample); // reset - clear the filter void reset(); // get filter size uint8_t get_filter_size() { return FILTER_SIZE; }; virtual T get_sample(uint8_t i) { return samples[i]; } protected: T samples[FILTER_SIZE]; // buffer of samples uint8_t sample_index; // pointer to the next empty slot in the buffer }; // Typedef for convenience typedef FilterWithBuffer FilterWithBufferInt16_Size2; typedef FilterWithBuffer FilterWithBufferInt16_Size3; typedef FilterWithBuffer FilterWithBufferInt16_Size4; typedef FilterWithBuffer FilterWithBufferInt16_Size5; typedef FilterWithBuffer FilterWithBufferInt16_Size6; typedef FilterWithBuffer FilterWithBufferInt16_Size7; typedef FilterWithBuffer FilterWithBufferUInt16_Size2; typedef FilterWithBuffer FilterWithBufferUInt16_Size3; typedef FilterWithBuffer FilterWithBufferUInt16_Size4; typedef FilterWithBuffer FilterWithBufferUInt16_Size5; typedef FilterWithBuffer FilterWithBufferUInt16_Size6; typedef FilterWithBuffer FilterWithBufferUInt16_Size7; typedef FilterWithBuffer FilterWithBufferInt32_Size2; typedef FilterWithBuffer FilterWithBufferInt32_Size3; typedef FilterWithBuffer FilterWithBufferInt32_Size4; typedef FilterWithBuffer FilterWithBufferInt32_Size5; typedef FilterWithBuffer FilterWithBufferInt32_Size6; typedef FilterWithBuffer FilterWithBufferInt32_Size7; typedef FilterWithBuffer FilterWithBufferUInt32_Size2; typedef FilterWithBuffer FilterWithBufferUInt32_Size3; typedef FilterWithBuffer FilterWithBufferUInt32_Size4; typedef FilterWithBuffer FilterWithBufferUInt32_Size5; typedef FilterWithBuffer FilterWithBufferUInt32_Size6; typedef FilterWithBuffer FilterWithBufferUInt32_Size7; // Constructor template FilterWithBuffer::FilterWithBuffer() : sample_index(0) { // clear sample buffer reset(); } // reset - clear all samples from the buffer template void FilterWithBuffer::reset() { // clear samples buffer for( int8_t i=0; i T FilterWithBuffer:: apply(T sample) { // add sample to array samples[sample_index++] = sample; // wrap index if necessary if( sample_index >= FILTER_SIZE ) sample_index = 0; // base class doesn't know what filtering to do so we just return the raw sample return sample; } #endif