tomwalters@0: // Copyright 2006-2010, Thomas Walters tomwalters@0: // tomwalters@0: // AIM-C: A C++ implementation of the Auditory Image Model tomwalters@0: // http://www.acousticscale.org/AIMC tomwalters@0: // tomwalters@45: // Licensed under the Apache License, Version 2.0 (the "License"); tomwalters@45: // you may not use this file except in compliance with the License. tomwalters@45: // You may obtain a copy of the License at tomwalters@0: // tomwalters@45: // http://www.apache.org/licenses/LICENSE-2.0 tomwalters@0: // tomwalters@45: // Unless required by applicable law or agreed to in writing, software tomwalters@45: // distributed under the License is distributed on an "AS IS" BASIS, tomwalters@45: // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. tomwalters@45: // See the License for the specific language governing permissions and tomwalters@45: // limitations under the License. tomwalters@0: tomwalters@0: /*! \file tomwalters@5: * \brief ERB calculations tomwalters@0: */ tomwalters@0: tomwalters@0: /*! \author: Thomas Walters tomwalters@0: * \date 2010/01/23 tomwalters@23: * \version \$Id$ tomwalters@0: */ tomwalters@0: tomwalters@11: #ifndef AIMC_SUPPORT_ERBTOOLS_H_ tomwalters@11: #define AIMC_SUPPORT_ERBTOOLS_H_ tomwalters@0: tomwalters@15: #include tomwalters@0: tomwalters@0: namespace aimc { tomwalters@0: class ERBTools { tomwalters@0: public: tomwalters@0: static float Freq2ERB(float freq) { tomwalters@0: return 21.4f * log10(4.37f * freq / 1000.0f + 1.0f); tomwalters@0: } tomwalters@0: tomwalters@0: static float Freq2ERBw(float freq) { tomwalters@0: return 24.7f * (4.37f * freq / 1000.0f + 1.0f); tomwalters@0: } tomwalters@5: tomwalters@5: static float ERB2Freq(float erb) { tomwalters@5: return (pow(10, (erb / 21.4f)) - 1.0f) / 4.37f * 1000.0f; tomwalters@5: } tomwalters@0: }; tomwalters@0: } tomwalters@0: tomwalters@11: #endif // AIMC_SUPPORT_ERBTOOLS_H_