1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
|
/* -----------------------------------------------------------------------------
*
* Monocasual Utils
*
* -----------------------------------------------------------------------------
*
* Copyright (C) 2021-2025 Giovanni A. Zuliani | Monocasual
*
* This file is part of Monocasual Utils.
*
* Monocasual Utils is free software: you can
* redistribute it and/or modify it under the terms of the GNU General
* Public License as published by the Free Software Foundation, either
* version 3 of the License, or (at your option) any later version.
*
* Monocasual Utils is distributed in the hope that it
* will be useful, but WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Giada - Monocasual Utils. If not, see
* <http://www.gnu.org/licenses/>.
*
* -------------------------------------------------------------------------- */
#include "math.h"
#include <cmath>
namespace mcl::utils::math
{
float linearToDB(float f)
{
return 20 * std::log10(f);
}
/* -------------------------------------------------------------------------- */
float dBtoLinear(float f)
{
return std::pow(10, f / 20.0f);
}
/* -------------------------------------------------------------------------- */
int quantize(int x, int step)
{
/* Source:
https://en.wikipedia.org/wiki/Quantization_(signal_processing)#Rounding_example */
return step * std::floor((x / (float)step) + 0.5f);
}
} // namespace mcl::utils::math
|