// Copyright (C) 2015 Jérôme Leclercq // This file is part of the "Nazara Engine - Mathematics module" // For conditions of distribution and use, see copyright notice in Config.hpp #pragma once #ifndef NAZARA_ALGORITHM_MATH_HPP #define NAZARA_ALGORITHM_MATH_HPP #include #include #include #include #ifndef M_PI #define M_PI 3.141592653589793238462643 #endif #ifndef M_SQRT2 #define M_SQRT2 1.4142135623730950488016887 #endif #ifndef M_SQRT3 #define M_SQRT3 1.7320508075688772935274463 #endif template T NzApproach(T value, T objective, T increment); template constexpr T NzClamp(T value, T min, T max); template T NzCountBits(T value); template constexpr T NzFromDegrees(T degrees); template constexpr T NzFromRadians(T radians); template constexpr T NzDegreeToRadian(T degrees); unsigned int NzGetNearestPowerOfTwo(unsigned int number); unsigned int NzGetNumberLength(signed char number); unsigned int NzGetNumberLength(unsigned char number); unsigned int NzGetNumberLength(int number); unsigned int NzGetNumberLength(unsigned int number); unsigned int NzGetNumberLength(long long number); unsigned int NzGetNumberLength(unsigned long long number); unsigned int NzGetNumberLength(float number, nzUInt8 precision = NAZARA_CORE_DECIMAL_DIGITS); unsigned int NzGetNumberLength(double number, nzUInt8 precision = NAZARA_CORE_DECIMAL_DIGITS); unsigned int NzGetNumberLength(long double number, nzUInt8 precision = NAZARA_CORE_DECIMAL_DIGITS); template unsigned int NzIntegralLog2(T number); template unsigned int NzIntegralLog2Pot(T pot); unsigned int NzIntegralPow(unsigned int base, unsigned int exponent); template T NzLerp(T from, T to, T2 interpolation); template T NzMultiplyAdd(T x, T y, T z); template T NzNormalizeAngle(T angle); template bool NzNumberEquals(T a, T b); template bool NzNumberEquals(T a, T b, T maxDifference); NzString NzNumberToString(long long number, nzUInt8 radix = 10); template T NzRadianToDegree(T radians); long long NzStringToNumber(NzString str, nzUInt8 radix = 10, bool* ok = nullptr); template constexpr T NzToDegrees(T angle); template constexpr T NzToRadians(T angle); #include #endif // NAZARA_ALGORITHM_MATH_HPP