|
| template<typename T > |
| bool | agx::_equivalent (T lhs, T rhs, T epsilon=T(AGX_EQUIVALENT_EPSILON)) |
| | Compare two values for equality.
|
| |
| template<typename T > |
| bool | agx::_relativelyEquivalent (T lhs, T rhs, T relativeEpsilon=T(AGX_EQUIVALENT_EPSILON)) |
| | Compare two values for relative equality.
|
| |
| template<typename T > |
| T | agx::absolute (T v) |
| | return the absolute value.
|
| |
| template<typename T1 , typename T2 > |
| T1 * | agx::align_ceil (const T1 *ptr, T2 alignment) |
| |
| template<typename T > |
| T | agx::align_ceil (T value, T alignment) |
| |
| template<typename T1 , typename T2 > |
| T1 * | agx::align_ceil2 (const T1 *ptr, T2 alignment) |
| |
| template<typename T > |
| T | agx::align_ceil2 (T value, T alignment) |
| |
| template<typename T1 , typename T2 > |
| T1 * | agx::align_floor (const T1 *ptr, T2 alignment) |
| |
| template<typename T > |
| T | agx::align_floor (T value, T alignment) |
| |
| template<typename T1 , typename T2 > |
| T1 * | agx::align_floor2 (const T1 *ptr, T2 alignment) |
| |
| template<typename T > |
| T | agx::align_floor2 (T value, T alignment) |
| |
| Int32 | agx::alignPowerOfTwo (Int32 value) |
| |
| Int64 | agx::alignPowerOfTwo (Int64 value) |
| |
| UInt32 | agx::alignPowerOfTwo (UInt32 value) |
| |
| UInt64 | agx::alignPowerOfTwo (UInt64 value) |
| |
| template<typename T1 , typename T2 , typename T3 > |
| T1 | agx::clamp (T1 v, T2 minimum, T3 maximum) |
| |
| template<typename T > |
| Real | agx::computeVolume (const T &a, const T &b, const T &c, const T &d) |
| | a, b, c, d sides of the tetrahedron
|
| |
| template<typename T > |
| Real | agx::computeVolume (const T &f1, const T &f2, const T &f3, const T &b1, const T &b2, const T &b3) |
| | compute the volume of a prism.
|
| |
| constexpr Real | agx::degreesToRadians (Real angle) |
| |
| bool | agx::equalsZero (double d, double eps=DBL_EPSILON) |
| |
| bool | agx::equalsZero (float f, float eps=FLT_EPSILON) |
| |
| bool | agx::equivalent (double lhs, double rhs, double epsilon=(double) AGX_EQUIVALENT_EPSILON) |
| | Compare two values for equality.
|
| |
| bool | agx::equivalent (float lhs, float rhs, double epsilon) |
| | Compare two values for equality.
|
| |
| bool | agx::equivalent (float lhs, float rhs, float epsilon=(float) AGX_EQUIVALENT_EPSILON) |
| | Compare two values for equality.
|
| |
| bool | agx::geq (double a, double b, double eps=(double) AGX_EQUIVALENT_EPSILON) |
| |
| bool | agx::geq (float a, float b, float eps=(float) AGX_EQUIVALENT_EPSILON) |
| |
| AGXCORE_EXPORT agx::UniformInt32Generator & | agx::getRandGenerator () |
| |
| template<typename T > |
| agx::UInt8 | agx::highestBitToIndex (T n) |
| |
| template<typename T > |
| T | agx::inverse (const T &value) |
| |
| int | agx::irandom (int min, int max) |
| |
| template<typename T1 , typename T2 > |
| bool | agx::isAligned (const T1 *ptr, T2 alignment) |
| |
| template<typename T > |
| bool | agx::isAligned (T value, T alignment) |
| |
| template<typename T > |
| bool | agx::isEven (T val) |
| |
| template<typename T > |
| bool | agx::isFinite (T v) |
| |
| template<typename T > |
| bool | agx::isInf (T v) |
| |
| template<typename T > |
| bool | agx::isNaN (T v) |
| |
| template<typename T > |
| bool | agx::isPowerOfTwo (T value) |
| |
| bool | agx::leq (double a, double b, double eps=(double) AGX_EQUIVALENT_EPSILON) |
| |
| bool | agx::leq (float a, float b, float eps=(float) AGX_EQUIVALENT_EPSILON) |
| |
| template<typename T1 , typename T2 > |
| T1 const | agx::lerp (T1 const &a, T1 const &b, T2 t) |
| | Linearly interpolate from a to b using t = {0..1}.
|
| |
| Int32 | agx::log2 (size_t val) |
| |
| template<typename T1 , typename T2 > |
| T1 const | agx::logInterpolate (T1 const &a, T1 const &b, T2 const &t) |
| | This function calculates a linear interpolation in a logarithmic space between two positive, non zero values a and b using t = {0..1} Both a and b must be > 0.
|
| |
| AGXCORE_EXPORT int | agx::nextPrime (int n) |
| |
| AGXCORE_EXPORT Real | agx::normalizedAngle (Real angle, bool positiveRange=false) |
| | Normalize an angle.
|
| |
| template<typename T1 , typename T2 > |
| T1 const | agx::parametricBlend (T1 const &a, T1 const &b, T2 t) |
| | Smooth interpolation from a to b using t = {0..1} The value returned will follow a ramp in/out and a parametric mid section.
|
| |
| template<typename T > |
| agx::UInt32 | agx::pow2Exponent (T value) |
| | Finds and returns n given value = 2^n.
|
| |
| constexpr Real | agx::radiansToDegrees (Real angle) |
| |
| template<typename T > |
| T | agx::random (T min, T max) |
| |
| bool | agx::relativelyEquivalent (double lhs, double rhs, double epsilon=(double) AGX_EQUIVALENT_EPSILON) |
| | Compare two values for relative equality.
|
| |
| bool | agx::relativelyEquivalent (float lhs, float rhs, double epsilon) |
| | Compare two values for relative equality.
|
| |
| bool | agx::relativelyEquivalent (float lhs, float rhs, float epsilon=(float) AGX_EQUIVALENT_EPSILON) |
| | Compare two values for relative equality.
|
| |
| template<typename T > |
| T | agx::sign (T v) |
| |
| template<typename T > |
| T | agx::signedSquare (T v) |
| |
| Real | agx::sinc (Real x, Real nearZero=Real(1E-4)) |
| | Sinc function.
|
| |
| template<typename T > |
| T | agx::square (T v) |
| |
| AGXCORE_EXPORT double | agx::strtod (const char *nptr, char **endptr) |
| | strtod ignoring global locale
|
| |
| AGXCORE_EXPORT float | agx::strtof (const char *nptr, char **endptr) |
| | strtod ignoring global locale
|
| |