2020-11-27 11:33:55 +01:00
|
|
|
#pragma once
|
2014-07-03 22:00:45 +02:00
|
|
|
//
|
2011-10-09 22:24:50 +02:00
|
|
|
// FILE: RunningAverage.h
|
2017-07-26 21:44:04 +02:00
|
|
|
// AUTHOR: Rob.Tillaart@gmail.com
|
2021-12-28 10:13:44 +01:00
|
|
|
// VERSION: 0.4.2
|
2016-12-02 00:06:08 +05:00
|
|
|
// DATE: 2016-dec-01
|
2020-11-27 11:33:55 +01:00
|
|
|
// PURPOSE: Arduino library to calculate the running average by means of a circular buffer
|
|
|
|
// URL: https://github.com/RobTillaart/RunningAverage
|
2011-10-09 22:24:50 +02:00
|
|
|
//
|
2020-11-27 11:33:55 +01:00
|
|
|
// HISTORY: See RunningAverage.cpp
|
2013-08-17 14:43:42 +02:00
|
|
|
|
2014-07-03 22:00:45 +02:00
|
|
|
|
|
|
|
#include "Arduino.h"
|
2013-08-17 14:43:42 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-12-28 10:13:44 +01:00
|
|
|
#define RUNNINGAVERAGE_LIB_VERSION (F("0.4.2"))
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
2014-07-03 22:00:45 +02:00
|
|
|
class RunningAverage
|
2011-10-09 22:24:50 +02:00
|
|
|
{
|
2014-07-03 22:00:45 +02:00
|
|
|
public:
|
2021-05-26 16:39:03 +02:00
|
|
|
explicit RunningAverage(const uint16_t size);
|
2017-07-26 21:44:04 +02:00
|
|
|
~RunningAverage();
|
|
|
|
|
2021-05-26 16:39:03 +02:00
|
|
|
void clear();
|
|
|
|
void add(const float value) { addValue(value); };
|
2021-11-24 10:03:41 +01:00
|
|
|
void addValue(const float value);
|
|
|
|
void fillValue(const float value, const uint16_t number);
|
|
|
|
float getValue(const uint16_t position);
|
2017-07-26 21:44:04 +02:00
|
|
|
|
2021-05-26 16:39:03 +02:00
|
|
|
float getAverage(); // iterates over all elements.
|
|
|
|
float getFastAverage() const; // reuses previous calculated values.
|
2017-07-26 21:44:04 +02:00
|
|
|
|
|
|
|
// return statistical characteristics of the running average
|
2021-05-26 16:39:03 +02:00
|
|
|
float getStandardDeviation() const;
|
|
|
|
float getStandardError() const;
|
2017-07-26 21:44:04 +02:00
|
|
|
|
|
|
|
// returns min/max added to the data-set since last clear
|
2021-05-26 16:39:03 +02:00
|
|
|
float getMin() const { return _min; };
|
|
|
|
float getMax() const { return _max; };
|
2017-07-26 21:44:04 +02:00
|
|
|
|
|
|
|
// returns min/max from the values in the internal buffer
|
2021-05-26 16:39:03 +02:00
|
|
|
float getMinInBuffer() const;
|
|
|
|
float getMaxInBuffer() const;
|
2017-07-26 21:44:04 +02:00
|
|
|
|
|
|
|
// return true if buffer is full
|
2021-05-26 16:39:03 +02:00
|
|
|
bool bufferIsFull() const { return _count == _size; };
|
2017-07-26 21:44:04 +02:00
|
|
|
|
2021-11-24 10:03:41 +01:00
|
|
|
float getElement(uint16_t index) const;
|
2017-07-26 21:44:04 +02:00
|
|
|
|
2021-05-26 16:39:03 +02:00
|
|
|
uint16_t getSize() const { return _size; }
|
|
|
|
uint16_t getCount() const { return _count; }
|
2017-07-26 21:44:04 +02:00
|
|
|
|
2021-05-26 16:39:03 +02:00
|
|
|
// use not all elements just a part from 0..partial-1
|
|
|
|
// (re)setting partial will clear the internal buffer.
|
2021-11-24 10:03:41 +01:00
|
|
|
void setPartial(const uint16_t partial = 0); // 0 ==> use all
|
2021-05-26 16:39:03 +02:00
|
|
|
uint16_t getPartial() { return _partial; };
|
2017-07-26 21:44:04 +02:00
|
|
|
|
2021-11-24 10:03:41 +01:00
|
|
|
|
|
|
|
// get some stats from the last count additions.
|
|
|
|
float getAverageLast(uint16_t count);
|
|
|
|
float getMinInBufferLast(uint16_t count);
|
|
|
|
float getMaxInBufferLast(uint16_t count);
|
|
|
|
|
|
|
|
|
2011-10-09 22:24:50 +02:00
|
|
|
protected:
|
2021-05-26 16:39:03 +02:00
|
|
|
uint16_t _size;
|
|
|
|
uint16_t _count;
|
|
|
|
uint16_t _index;
|
|
|
|
uint16_t _partial;
|
|
|
|
float _sum;
|
|
|
|
float* _array;
|
|
|
|
float _min;
|
|
|
|
float _max;
|
2011-10-09 22:24:50 +02:00
|
|
|
};
|
|
|
|
|
2021-11-24 10:03:41 +01:00
|
|
|
|
2020-11-27 11:33:55 +01:00
|
|
|
// -- END OF FILE --
|
2021-11-24 10:03:41 +01:00
|
|
|
|