00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef MARSYAS_PeakDistanceHorizontality_H
00020 #define MARSYAS_PeakDistanceHorizontality_H
00021
00022 #include "MarSystem.h"
00023
00024 namespace Marsyas
00025 {
00040 class marsyas_EXPORT PeakDistanceHorizontality: public MarSystem
00041 {
00042 private:
00043
00045 void addControls();
00046
00048 void myUpdate(MarControlPtr sender);
00049
00050 mrs_real ComputeHorizontality(mrs_real diffX, mrs_real diffY);
00051
00052
00053 inline mrs_real sigmoid (mrs_real val)
00054 {
00055 return (1. / (1. + exp(sigSteepness_ * (val - sigCutOff_))));
00056 }
00057
00058 inline mrs_real gaussian (mrs_real x)
00059 {
00060 return exp (-(x*x)/(2*(sigCutOff_*sigCutOff_)));
00061 }
00062
00064 MarControlPtr ctrl_horizvert_,
00065 ctrl_rangeX_,
00066 ctrl_rangeY_;
00067
00068 mrs_realvec weights_;
00069 mrs_real sigSteepness_,
00070 sigCutOff_;
00071
00072 public:
00074 PeakDistanceHorizontality(std::string name);
00075
00077 PeakDistanceHorizontality(const PeakDistanceHorizontality& a);
00078
00080 ~PeakDistanceHorizontality();
00081
00083 MarSystem* clone() const;
00084
00086 void myProcess(realvec& in, realvec& out);
00087 };
00088
00089 }
00090
00091
00092 #endif
00093
00094