eDSP  0.0.1
A cross-platform DSP library written in C++.
hertz2bark.hpp
Go to the documentation of this file.
1 /*
2 * eDSP, A cross-platform Digital Signal Processing library written in modern C++.
3 * Copyright (C) 2018 Mohammed Boujemaoui Boulaghmoudi, All rights reserved.
4 *
5 * This program is free software: you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the Free
7 * Software Foundation, either version 3 of the License, or (at your option)
8 * any later version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13 * more details.
14 *
15 * You should have received a copy of the GNU General Public License along width
16 * this program. If not, see <http://www.gnu.org/licenses/>
17 *
18 * Filename: hz2bark.hpp
19 * Author: Mohammed Boujemaoui
20 * Date: 12/10/18
21 */
22 
23 #ifndef EDSP_HZ2BARK_HPP
24 #define EDSP_HZ2BARK_HPP
25 
26 #include <cmath>
27 
28 namespace edsp { inline namespace converter {
29 
45  template <typename T>
46  constexpr T hertz2bark(T f) noexcept {
47  const auto b = (26.81 * f) / (1960 + f) - 0.53;
48  if (b < 2) {
49  b += 0.15 * (2 - b);
50  }
51  if (b > 20.1) {
52  b += 0.22 * (b - 20.1);
53  }
54  return b;
55  }
56 
72  template <typename T>
73  constexpr T bark2band(T z) noexcept {
74  return 52548.0 / (z * z - 52.56 * z + 690.39);
75  }
76 
77 }} // namespace edsp::converter
78 
79 #endif //EDSP_HZ2BARK_HPP
constexpr T bark2band(T z) noexcept
Converts a frequency in Hertz into its equivalent Bark scale value.
Definition: hertz2bark.hpp:73
Definition: amplifier.hpp:29