00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #include "AMDF.h"
00020
00021
00022 using std::ostringstream;
00023
00024 using namespace Marsyas;
00025
00026 AMDF::AMDF(mrs_string name):MarSystem("AMDF", name)
00027 {
00028
00029
00030 }
00031
00032
00033 AMDF::~AMDF()
00034 {
00035 }
00036
00037
00038 MarSystem*
00039 AMDF::clone() const
00040 {
00041 return new AMDF(*this);
00042 }
00043
00044 void
00045 AMDF::myUpdate(MarControlPtr sender)
00046 {
00047 (void) sender;
00048 MRSDIAG("AMDF.cpp - AMDF:myUpdate");
00049
00050 setctrl("mrs_natural/onSamples", getctrl("mrs_natural/inSamples"));
00051 setctrl("mrs_natural/onObservations", getctrl("mrs_natural/inObservations"));
00052 setctrl("mrs_real/osrate", getctrl("mrs_real/israte"));
00053
00054 setctrl("mrs_string/onObsNames", getctrl("mrs_string/inObsNames"));
00055 }
00056
00057 void
00058 AMDF::myProcess(realvec& in, realvec& out)
00059 {
00060 mrs_natural o,t;
00061
00062
00063
00064
00065 mrs_natural i,k;
00066 mrs_real temp;
00067
00068 for (o=0; o < inObservations_; o++)
00069 for (t = 0; t < inSamples_; t++)
00070 {
00071 out(o,t) = 0.0;
00072 for (i=t, k=0; i < inSamples_; ++i, k++)
00073 {
00074 temp = in(o,i) - in(o,k);
00075 if (temp < 0)
00076 out(o,t) -= temp;
00077 else
00078 out(o,t) += temp;
00079 }
00080 }
00081
00082 }
00083
00084
00085
00086
00087
00088
00089
00090
00091