Mercurial > hg > beaglert
diff include/stats.hpp @ 135:e77e2e712fbc ClockSync
To work with the ClockSync plugin
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Sat, 12 Sep 2015 20:05:55 +0100 |
parents | |
children | aac018615930 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/include/stats.hpp Sat Sep 12 20:05:55 2015 +0100 @@ -0,0 +1,64 @@ +#ifndef STATS_HPP_INCLUDED +#define STATS_HPP_INCLUDED +#include <stdlib.h> +#include <stdio.h> +#include <string.h> + +template<class TYPE> +class MovingAverage{ +private: + TYPE* array; + int length; + int pointer; + TYPE sum; + double scale; + double average; + void dealloc(){ + free(array); + // delete array; + } + + void init(int aLength){ + length=aLength; + scale=1.0/length; + // array= new TYPE(length); // for some reason this causes memory corruption, so I am using malloc() instead... + array=(TYPE*)malloc(sizeof(TYPE)*length); + sum=0; + if(array==NULL) + printf("Error while allocating array\n"); + memset(array, 0, sizeof(TYPE)*length); + pointer=0; + } +public: + MovingAverage(){ + init(0); + } + MovingAverage(int aLength){ + init(aLength); + } + ~MovingAverage(){ + dealloc(); + } + int getLength(){ + return length; + } + void setLength(int aLength){ + dealloc(); + init(aLength); + } + double add(TYPE newElement){ + sum-=array[pointer]; + array[pointer]=newElement; + sum+=newElement; + average=sum*scale; + pointer++; + if(pointer==length) + pointer=0; + return average; + } + double getAverage(){ + return average; + } +}; + +#endif /* STATS_HPP_INCLUDED */ \ No newline at end of file