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 53 54 55 56 57 58 59 60 61 62 63 64 65
|
/* -----------------------------------------------------------------------------
*
* 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/>.
*
* -------------------------------------------------------------------------- */
#ifndef MONOCASUAL_UTILS_MATH_H
#define MONOCASUAL_UTILS_MATH_H
#include <type_traits>
namespace mcl::utils::math
{
float linearToDB(float f);
float dBtoLinear(float f);
int quantize(int x, int step);
/* -------------------------------------------------------------------------- */
/* map (1)
Maps 'x' in range [a, b] to a new range [w, z]. Source:
https://en.wikipedia.org/wiki/Linear_equation#Two-point_form*/
template <typename TI, typename TO>
constexpr TO map(TI x, TI a, TI b, TO w, TO z)
{
static_assert(std::is_arithmetic_v<TI>);
static_assert(std::is_arithmetic_v<TO>);
if (a == b) // Prevents division by zero (undefined behavior)
return x;
return (((x - a) / (double)(b - a)) * (z - w)) + w;
}
/* map (2)
Maps 'x' in range [0, b) to a new range [0, z]. */
template <typename TI, typename TO>
constexpr TO map(TI x, TI b, TO z)
{
return map(x, static_cast<TI>(0), b, static_cast<TO>(0), z);
}
} // namespace mcl::utils::math
#endif
|