00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef MARSYAS_ResampleSinc_H
00020 #define MARSYAS_ResampleSinc_H
00021
00022 #include "MarSystem.h"
00023
00024 namespace Marsyas
00025 {
00046 class ResampleSinc: public MarSystem
00047 {
00048
00049
00050
00051
00052
00053 private:
00054
00055 void addControls();
00056 MarControlPtr ctrl_windowedMode_;
00057 MarControlPtr ctrl_samplingRateAdjustmentMode_;
00058 MarControlPtr ctrl_offStart_;
00059 MarControlPtr ctrl_offEnd_;
00060 MarControlPtr ctrl_stretch_;
00061 void myUpdate(MarControlPtr sender);
00062 mrs_real sinc(mrs_real t);
00063 mrs_real window(mrs_real position);
00064
00065 public:
00066 ResampleSinc(std::string name);
00067 ResampleSinc(const ResampleSinc& a);
00068 ~ResampleSinc();
00069 MarSystem* clone() const;
00070
00071 void myProcess(realvec& in, realvec& out);
00072
00073
00074 };
00075
00076 }
00077
00078 #endif