Mercurial > hg > tipic
view src/FeatureDownsample.h @ 37:47d5321a57c2
Fix downsampling: correct window to match MATLAB implementation, apply re-normalisation
author | Chris Cannam |
---|---|
date | Thu, 01 Oct 2015 11:21:37 +0100 |
parents | 13276c5113be |
children | 00b6ae41efbe |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ #ifndef FEATURE_DOWNSAMPLE_H #define FEATURE_DOWNSAMPLE_H #include <vector> #include "Types.h" //!!! doc: class maintains state class Filter; class FeatureDownsample { public: struct Parameters { int featureSize; int downsampleFactor; int windowLength; int normP; // 0 = no normalisation, 1 = L^1, 2 = L^2 double normThresh; Parameters() : featureSize(1), downsampleFactor(10), windowLength(41), normP(2), normThresh(1e-6) { } }; FeatureDownsample(Parameters params); ~FeatureDownsample(); void reset(); RealBlock process(const RealBlock &in); RealBlock getRemainingOutput(); private: Parameters m_params; std::vector<Filter *> m_filters; int m_toDrop; int m_toNext; int m_inCount; int m_outCount; }; #endif