// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- // // This is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License as published by the // Free Software Foundation; either version 2.1 of the License, or (at // your option) any later version. // /// @file AverageFilter.h /// @brief A class to provide the average of a number of samples #ifndef AverageFilter_h #define AverageFilter_h #include #include #include // 1st parameter is the type of data being filtered. // 2nd parameter is a larger data type used during summation to prevent overflows // 3rd parameter is the number of elements in the filter template class AverageFilter : public FilterWithBuffer { public: // constructor AverageFilter() : FilterWithBuffer(), _num_samples(0) {}; // apply - Add a new raw value to the filter, retrieve the filtered result virtual T apply(T sample); // reset - clear the filter virtual void reset(); private: uint8_t _num_samples; // the number of samples in the filter, maxes out at size of the filter }; // Typedef for convenience (1st argument is the data type, 2nd is a larger datatype to handle overflows, 3rd is buffer size) typedef AverageFilter AverageFilterInt8_Size2; typedef AverageFilter AverageFilterInt8_Size3; typedef AverageFilter AverageFilterInt8_Size4; typedef AverageFilter AverageFilterInt8_Size5; typedef AverageFilter AverageFilterUInt8_Size2; typedef AverageFilter AverageFilterUInt8_Size3; typedef AverageFilter AverageFilterUInt8_Size4; typedef AverageFilter AverageFilterUInt8_Size5; typedef AverageFilter AverageFilterInt16_Size2; typedef AverageFilter AverageFilterInt16_Size3; typedef AverageFilter AverageFilterInt16_Size4; typedef AverageFilter AverageFilterInt16_Size5; typedef AverageFilter AverageFilterUInt16_Size2; typedef AverageFilter AverageFilterUInt16_Size3; typedef AverageFilter AverageFilterUInt16_Size4; typedef AverageFilter AverageFilterUInt16_Size5; typedef AverageFilter AverageFilterInt32_Size2; typedef AverageFilter AverageFilterInt32_Size3; typedef AverageFilter AverageFilterInt32_Size4; typedef AverageFilter AverageFilterInt32_Size5; typedef AverageFilter AverageFilterUInt32_Size2; typedef AverageFilter AverageFilterUInt32_Size3; typedef AverageFilter AverageFilterUInt32_Size4; typedef AverageFilter AverageFilterUInt32_Size5; typedef AverageFilter AverageFilterFloat_Size5; // Public Methods ////////////////////////////////////////////////////////////// template T AverageFilter::apply(T sample) { U result = 0; // call parent's apply function to get the sample into the array FilterWithBuffer::apply(sample); // increment the number of samples so far _num_samples++; if( _num_samples > FILTER_SIZE || _num_samples == 0 ) _num_samples = FILTER_SIZE; // get sum of all values - there is a risk of overflow here that we ignore for(uint8_t i=0; i::samples[i]; return (T)(result / _num_samples); } // reset - clear all samples template void AverageFilter::reset() { // call parent's apply function to get the sample into the array FilterWithBuffer::reset(); // clear our variable _num_samples = 0; } #endif