SpectralCombTriang.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 _SpectralCombTriang_
00025 #define _SpectralCombTriang_
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 SpectralCombTriang: public FrameTransformationTmpl<Spectrum>
00037 {
00038 InPort<Spectrum> mIn;
00039 OutPort<Spectrum> mOut;
00040
00041 FloatInControl mFundamentalCtl;
00042 FloatInControl mAmount;
00043 public:
00044 const char* GetClassName() const
00045 {
00046 return "SpectralCombTriang";
00047 }
00048
00049 SpectralCombTriang()
00050 :
00051 mIn("In Spectrum", this),
00052 mOut("Out Spectrum", this),
00053 mFundamentalCtl("Fundamental", this),
00054 mAmount("Amount", this)
00055 {
00056 Configure( FrameTransformationConfig() );
00057 }
00058
00059 ~SpectralCombTriang() {}
00060
00061 virtual bool InitControls()
00062 {
00063 mFundamentalCtl.DoControl(100);
00064 mAmount.DoControl(0);
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 TData GetGain(int fundamental, int binPos, int bandNum);
00086
00087 };
00088 };
00089
00090 #endif // _SpectralCombTriang_