SpectralReject.cxx
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 #include "SpectralReject.hxx"
00023 #include "ProcessingFactory.hxx"
00024 
00025 namespace CLAM
00026 {
00027 
00028 namespace Hidden
00029 {
00030         static const char * metadata[] = {
00031                 "key", "SpectralReject",
00032         
00033         
00034                 0
00035         };
00036         static FactoryRegistrator<ProcessingFactory, SpectralReject> reg = metadata;
00037 }
00038 
00039 bool SpectralReject::Do(const Spectrum& in, Spectrum& out)
00040 {
00041         if (!mConfig.GetPreserveOuts())
00042         {
00043                 out = in; 
00044         }
00045         DataArray& inMag = in.GetMagBuffer();
00046         DataArray& outMag = out.GetMagBuffer();
00047         
00048         int spectrumSize = in.GetSize();
00049         
00050         
00051         TData limit = log2lin(mAmount.GetLastValue());
00052         int i;  
00053         for(i = 0; i<spectrumSize; i++)
00054         {
00055                 if(inMag[i] > limit) outMag[i] = 0.;
00056                 else outMag[i] = inMag[i];
00057         }
00058         return true;
00059 }
00060 
00061 
00062 }
00063