00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #include "Deesser.hxx"
00023 #include "ProcessingFactory.hxx"
00024
00025 namespace CLAM
00026 {
00027
00028 namespace Hidden
00029 {
00030 static const char * metadata[] = {
00031 "key", "Deesser",
00032
00033
00034 0
00035 };
00036 static FactoryRegistrator<ProcessingFactory, Deesser> reg = metadata;
00037 }
00038
00039 bool Deesser::Do(const Spectrum& in, Spectrum& out)
00040 {
00041 out = in;
00042
00043 DataArray& oMag = out.GetMagBuffer();
00044 DataArray& iMag = in.GetMagBuffer();
00045
00046 int spectrumSize = in.GetSize();
00047
00048 TData spectralResolution = spectrumSize/in.GetSpectralRange();
00049
00050 int lowCutoff = Round(mLowCutoffFreqCtl.GetLastValue()* spectralResolution);
00051 int highCutoff = Round(mHighCutoffFreqCtl.GetLastValue()* spectralResolution);
00052
00053 TData midFreq = mLowCutoffFreqCtl.GetLastValue()+(mHighCutoffFreqCtl.GetLastValue()-mLowCutoffFreqCtl.GetLastValue())*0.5;
00054 SendFloatToInControl(mNotch,"Amount",midFreq);
00055 SendFloatToInControl(mNotch,"Bandwidth",mHighCutoffFreqCtl.GetLastValue()-mLowCutoffFreqCtl.GetLastValue());
00056
00057
00058 TData threshold = log2lin(mThresholdCtl.GetLastValue());
00059
00060 int i;
00061 TData maxMag = 0;
00062 for( i = lowCutoff; i<highCutoff; i++)
00063 {
00064 if(iMag[i]>threshold) oMag[i] = threshold;
00065
00066
00067
00068 }
00069
00070
00071
00072
00073 return true;
00074 }
00075
00076
00077 }
00078