2014-07-03 16:00:45 -04:00
|
|
|
//
|
2011-10-09 16:24:50 -04:00
|
|
|
// FILE: RunningAverage.cpp
|
|
|
|
// AUTHOR: Rob Tillaart
|
2014-12-16 16:04:21 -05:00
|
|
|
// VERSION: 0.2.05
|
|
|
|
// DATE: 2014-dec-16
|
2011-10-09 16:24:50 -04:00
|
|
|
// PURPOSE: RunningAverage library for Arduino
|
|
|
|
//
|
2014-07-03 16:00:45 -04:00
|
|
|
// The library stores the last N individual values in a circular buffer,
|
|
|
|
// to calculate the running average.
|
2011-10-09 16:24:50 -04:00
|
|
|
//
|
2014-07-03 16:00:45 -04:00
|
|
|
// HISTORY:
|
2011-10-09 16:24:50 -04:00
|
|
|
// 0.1.00 - 2011-01-30 initial version
|
|
|
|
// 0.1.01 - 2011-02-28 fixed missing destructor in .h
|
2013-08-17 08:43:42 -04:00
|
|
|
// 0.2.00 - 2012-??-?? Yuval Naveh added trimValue (found on web)
|
|
|
|
// http://stromputer.googlecode.com/svn-history/r74/trunk/Arduino/Libraries/RunningAverage/RunningAverage.cpp
|
|
|
|
// 0.2.01 - 2012-11-21 refactored
|
|
|
|
// 0.2.02 - 2012-12-30 refactored trimValue -> fillValue
|
2014-07-03 16:00:45 -04:00
|
|
|
// 0.2.03 - 2013-11-31 getElement
|
|
|
|
// 0.2.04 - 2014-07-03 added memory protection
|
2014-12-16 16:04:21 -05:00
|
|
|
// 0.2.05 - 2014-12-16 changed float -> double
|
2011-10-09 16:24:50 -04:00
|
|
|
//
|
|
|
|
// Released to the public domain
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "RunningAverage.h"
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
RunningAverage::RunningAverage(int n)
|
|
|
|
{
|
2014-07-03 16:00:45 -04:00
|
|
|
_size = n;
|
2014-12-16 16:04:21 -05:00
|
|
|
_ar = (double*) malloc(_size * sizeof(double));
|
2014-07-03 16:00:45 -04:00
|
|
|
if (_ar == NULL) _size = 0;
|
|
|
|
clear();
|
2011-10-09 16:24:50 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
RunningAverage::~RunningAverage()
|
|
|
|
{
|
2014-07-03 16:00:45 -04:00
|
|
|
if (_ar != NULL) free(_ar);
|
2011-10-09 16:24:50 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// resets all counters
|
2014-07-03 16:00:45 -04:00
|
|
|
void RunningAverage::clear()
|
|
|
|
{
|
|
|
|
_cnt = 0;
|
|
|
|
_idx = 0;
|
|
|
|
_sum = 0.0;
|
|
|
|
for (int i = 0; i< _size; i++) _ar[i] = 0.0; // needed to keep addValue simple
|
2011-10-09 16:24:50 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// adds a new value to the data-set
|
2014-12-16 16:04:21 -05:00
|
|
|
void RunningAverage::addValue(double f)
|
2011-10-09 16:24:50 -04:00
|
|
|
{
|
2014-07-03 16:00:45 -04:00
|
|
|
if (_ar == NULL) return;
|
|
|
|
_sum -= _ar[_idx];
|
|
|
|
_ar[_idx] = f;
|
|
|
|
_sum += _ar[_idx];
|
|
|
|
_idx++;
|
|
|
|
if (_idx == _size) _idx = 0; // faster than %
|
|
|
|
if (_cnt < _size) _cnt++;
|
2011-10-09 16:24:50 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// returns the average of the data-set added sofar
|
2014-12-16 16:04:21 -05:00
|
|
|
double RunningAverage::getAverage()
|
2011-10-09 16:24:50 -04:00
|
|
|
{
|
2014-07-03 16:00:45 -04:00
|
|
|
if (_cnt == 0) return NAN;
|
|
|
|
return _sum / _cnt;
|
|
|
|
}
|
|
|
|
|
|
|
|
// returns the value of an element if exist, 0 otherwise
|
2014-12-16 16:04:21 -05:00
|
|
|
double RunningAverage::getElement(uint8_t idx)
|
2014-07-03 16:00:45 -04:00
|
|
|
{
|
|
|
|
if (idx >=_cnt ) return NAN;
|
|
|
|
return _ar[idx];
|
2011-10-09 16:24:50 -04:00
|
|
|
}
|
|
|
|
|
2013-08-17 08:43:42 -04:00
|
|
|
// fill the average with a value
|
|
|
|
// the param number determines how often value is added (weight)
|
|
|
|
// number should preferably be between 1 and size
|
2014-12-16 16:04:21 -05:00
|
|
|
void RunningAverage::fillValue(double value, int number)
|
2013-08-17 08:43:42 -04:00
|
|
|
{
|
2014-07-03 16:00:45 -04:00
|
|
|
clear();
|
|
|
|
for (int i = 0; i < number; i++)
|
|
|
|
{
|
|
|
|
addValue(value);
|
|
|
|
}
|
2013-08-17 08:43:42 -04:00
|
|
|
}
|
2011-10-09 16:24:50 -04:00
|
|
|
// END OF FILE
|