/* * RmsFunc.hh * * Created on: Jun 23, 2018 * Author: benjamin */ #ifndef RMSFUNC_HH_ #define RMSFUNC_HH_ #include "AbstractFunc.hh" #include "Toolbox.hh" namespace AMDA { namespace Parameters { namespace StatisticFunctions { template OutputElemType computeRms(std::list>& mem, OutputElemType& nanVal) { OutputElemType result = nanVal; if (mem.empty()) { return result; } result << ElemNull(); int n = 0; for (auto val : mem) { if (isNAN(val.second)) continue; result = result+StatisticFunctions::square(val.second); ++n; } if (n == 0) { result << NotANumber(); return result; } result = 1./n*result; result = StatisticFunctions::root_square(result); return result; } /** * @class RmsFunc * @brief * @details This class implements AbstractFunc. */ template class RmsFunc : public ClassicAbstractFunc { public: /** * @brief Constructor. */ RmsFunc(Process& pProcess, TimeIntervalListSPtr pTimeIntervalList, ParamDataSpec& paramInput, double windowtime) : ClassicAbstractFunc(pProcess, pTimeIntervalList, paramInput, windowtime) { } virtual ~RmsFunc() { } OutputElemType compute() { return computeRms(ClassicAbstractFunc::_mem, ClassicAbstractFunc::_nanVal); } }; /** * @class RmsFuncSm * @brief * @details This class implements AbstractFunc. */ template class RmsSmFunc : public SmAbstractFunc { public: /** * @brief Constructor. */ RmsSmFunc(Process& pProcess, TimeIntervalListSPtr pTimeIntervalList, ParamDataSpec& paramInput, double windowtime) : SmAbstractFunc(pProcess, pTimeIntervalList, paramInput, windowtime) { } virtual ~RmsSmFunc() { } OutputElemType compute() { return computeRms(SmAbstractFunc::_mem, SmAbstractFunc::_nanVal); } }; } /* namespace StatisticFunctions */ } /* namespace Parameters */ } /* namespace AMDA */ #endif /* RMSFUNC_HH_ */