28#include <ArmarXCore/interface/observers/Filters.h>
55 template <
typename Type>
59 const double sigma = filterSizeInMs / 2.5;
62 double weightedSum = 0;
63 double sumOfWeight = 0;
66 const double sqrt2PI = sqrt(2 *
M_PI);
69 for (
auto it = map.begin(); it != map.end(); it++)
72 value = VariantPtr::dynamicCast(it->second)->get<Type>();
73 double diff = 0.001 * (it->first - map.rbegin()->first);
75 double squared = diff * diff;
76 const double gaussValue = exp(-squared / (2 * sigma * sigma)) / (sigma * sqrt2PI);
77 sumOfWeight += gaussValue;
78 weightedSum += gaussValue * value;
82 result = weightedSum / sumOfWeight;
99 getProperties(
const Ice::Current&
c = Ice::emptyCurrent)
const override;
101 const Ice::Current&
c = Ice::emptyCurrent)
override;
void setProperties(const StringFloatDictionary &newValues, const Ice::Current &c=Ice::emptyCurrent) override
GaussianFilter(int filterSizeInMs=200, int windowSize=20)
GaussianFilter.
VariantBasePtr calculate(const Ice::Current &c=Ice::emptyCurrent) const override
StringFloatDictionary getProperties(const Ice::Current &c=Ice::emptyCurrent) const override
ParameterTypeList getSupportedTypes(const Ice::Current &c=Ice::emptyCurrent) const override
This filter supports: Int, Long, Float, Double.
Type calcGaussianFilteredValue(const TimeVariantBaseMap &map) const
std::deque< std::pair< long, VariantBasePtr > > TimeVariantBaseMap
::IceInternal::Handle<::armarx::VariantBase > VariantBasePtr