tomwalters@397: /*! tomwalters@397: * \file tomwalters@397: * \brief Linear frequency scale for generating filter banks and their frequencies tomwalters@397: * tomwalters@397: * \author Willem van Engen tomwalters@397: * \date created 2006/09/26 tomwalters@397: * \version \$Id: ScaleLinear.h 459 2007-11-08 11:50:04Z tom $ tomwalters@397: */ tomwalters@397: /* (c) 2006, University of Cambridge, Medical Research Council tomwalters@397: * http://www.pdn.cam.ac.uk/groups/cnbh/aimmanual tomwalters@397: */ tomwalters@397: #ifndef __MODULE_SCALE_LINEAR_H__ tomwalters@397: #define __MODULE_SCALE_LINEAR_H__ tomwalters@397: tom@400: #include "Modules/Output/Graphics/Scale/Scale.h" tom@400: tom@400: namespace aimc { tomwalters@397: tomwalters@397: /*! tomwalters@397: * \class ScaleLinear "Modules/Scale/ScaleLinear.h" tomwalters@397: * \brief Linear frequency scale for generating filter banks and their frequencies tomwalters@397: * tomwalters@397: * It is very advisable to use Scale::Create() to an instance of this scale. tomwalters@397: * tomwalters@397: * In terms of scaling, this is of course an identity transformation. tomwalters@397: */ tomwalters@397: class ScaleLinear : public Scale { tomwalters@397: public: tomwalters@398: ScaleLinear(unsigned int min, unsigned int max, float density) tomwalters@398: : Scale(min, max, density) { m_iType = SCALE_LINEAR; m_sName = "linear"; }; tomwalters@397: tomwalters@398: float FromLinear(float fFreq) { tomwalters@398: return fFreq; tomwalters@398: }; tomwalters@397: tomwalters@398: float ToLinear(float fFreq) { tomwalters@398: return fFreq; tomwalters@398: }; tomwalters@397: }; tom@400: } // namepspace aimc tomwalters@397: #endif /* __MODULE_SCALE_LINEAR_H__ */