|
CLAM-Development
1.3
|
00001 /* 00002 * Copyright (c) 2001-2004 MUSIC TECHNOLOGY GROUP (MTG) 00003 * UNIVERSITAT POMPEU FABRA 00004 * 00005 * 00006 * This program is free software; you can redistribute it and/or modify 00007 * it under the terms of the GNU General Public License as published by 00008 * the Free Software Foundation; either version 2 of the License, or 00009 * (at your option) any later version. 00010 * 00011 * This program is distributed in the hope that it will be useful, 00012 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00014 * GNU General Public License for more details. 00015 * 00016 * You should have received a copy of the GNU General Public License 00017 * along with this program; if not, write to the Free Software 00018 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00019 * 00020 */ 00021 00022 #include "SMSTranspose.hxx" 00023 #include <CLAM/ProcessingFactory.hxx> 00024 #include <cmath> 00025 00026 namespace CLAM 00027 { 00028 namespace Hidden 00029 { 00030 static const char * metadata[] = { 00031 "key", "SMSTranspose", 00032 "category", "SMS Transformations", 00033 "description", "SMSTranspose", 00034 0 00035 }; 00036 static FactoryRegistrator<ProcessingFactory, SMSTranspose> reg = metadata; 00037 } 00038 00039 bool SMSTranspose::Do(const SpectralPeakArray& in, SpectralPeakArray& out) 00040 { 00041 static const TData toneFactor = std::pow(2.,1./12.); 00042 00043 //TODO big cludge for streaming 00044 if ( !mConfig.GetPreserveOuts() ) out = in; 00045 00046 DataArray& ifreqArray=in.GetFreqBuffer(); 00047 DataArray& ofreqArray=out.GetFreqBuffer(); 00048 TSize nPeaks=in.GetnPeaks(); 00049 TData amount=mControl.GetLastValue(); 00050 for(int i=0;i<nPeaks;i++) 00051 ofreqArray[i]=ifreqArray[i]*std::pow(toneFactor,amount); 00052 return true; 00053 } 00054 00055 00056 } 00057
1.7.6.1