00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef MARSYAS_HARMONICSTRENGTH_H
00020 #define MARSYAS_HARMONICSTRENGTH_H
00021
00022 #include "MarSystem.h"
00023
00024 namespace Marsyas
00025 {
00049 class marsyas_EXPORT HarmonicStrength: public MarSystem
00050 {
00051 private:
00052
00054 void addControls();
00055
00057 void myUpdate(MarControlPtr sender);
00058
00059
00060 MarControlPtr ctrl_base_frequency_;
00061 MarControlPtr ctrl_harmonics_;
00062 MarControlPtr ctrl_harmonicsSize_;
00063 MarControlPtr ctrl_harmonicsWidth_;
00064 MarControlPtr ctrl_inharmonicity_B_;
00065
00066 mrs_real find_peak_magnitude(mrs_real central_bin,
00067 mrs_realvec& in, mrs_natural t,
00068 mrs_real low, mrs_real high);
00069 mrs_real quadratic_interpolation(mrs_real best_bin,
00070 mrs_realvec& in, mrs_natural t);
00071
00072 public:
00074 HarmonicStrength(std::string name);
00075
00077 HarmonicStrength(const HarmonicStrength& a);
00078
00080 ~HarmonicStrength();
00081
00083 MarSystem* clone() const;
00084
00086 void myProcess(realvec& in, realvec& out);
00087 };
00088
00089 }
00090
00091
00092 #endif
00093
00094