Peakalizer.hxx
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024 #ifndef _Peakalizer_
00025 #define _Peakalizer_
00026
00027 #include "InPort.hxx"
00028 #include "OutPort.hxx"
00029 #include "InControl.hxx"
00030 #include "Frame.hxx"
00031 #include "FrameTransformation.hxx"
00032 #include "FrameTransformationConfig.hxx"
00033
00034 namespace CLAM{
00035
00036 class Peakalizer: public FrameTransformationTmpl<Spectrum>
00037 {
00038 InPort<Spectrum> mIn;
00039 OutPort<Spectrum> mOut;
00040
00041 FloatInControl mThresholdCtl;
00042 FloatInControl mBandWidthCtl;
00043 public:
00044 const char* GetClassName() const
00045 {
00046 return "Peakalizer";
00047 }
00048
00049 Peakalizer()
00050 :
00051 mIn("In Spectrum", this),
00052 mOut("Out Spectrum", this),
00053 mThresholdCtl("Threshold", this),
00054 mBandWidthCtl("Bandwidth", this)
00055 {
00056 Configure( FrameTransformationConfig() );
00057 }
00058
00059 ~Peakalizer() {}
00060
00061 virtual bool InitControls()
00062 {
00063 mThresholdCtl.DoControl(-60);
00064 mBandWidthCtl.DoControl(500);
00065
00066 return true;
00067 }
00068
00069 bool Do(const Frame& in, Frame& out)
00070 {
00071 return Do(in.GetSpectrum(),
00072 out.GetSpectrum());
00073 }
00074
00075 bool Do(const Spectrum& in, Spectrum& out);
00076
00077 bool Do()
00078 {
00079 bool result = Do(mIn.GetData(), mOut.GetData());
00080 mIn.Consume();
00081 mOut.Produce();
00082 return result;
00083 }
00084 private:
00085 DataArray mMag;
00086 };
00087 };
00088
00089 #endif // _Peakalizer_