8 #ifndef OPENVDB_MATH_HAS_BEEN_INCLUDED
9 #define OPENVDB_MATH_HAS_BEEN_INCLUDED
13 #include <hboost/numeric/conversion/conversion_traits.hpp>
21 #include <type_traits>
28 #if defined(__INTEL_COMPILER)
29 #define OPENVDB_NO_FP_EQUALITY_WARNING_BEGIN \
30 _Pragma("warning (push)") \
31 _Pragma("warning (disable:1572)")
32 #define OPENVDB_NO_FP_EQUALITY_WARNING_END \
33 _Pragma("warning (pop)")
34 #elif defined(__clang__)
35 #define OPENVDB_NO_FP_EQUALITY_WARNING_BEGIN \
36 PRAGMA(clang diagnostic push) \
37 PRAGMA(clang diagnostic ignored "-Wfloat-equal")
38 #define OPENVDB_NO_FP_EQUALITY_WARNING_END \
39 PRAGMA(clang diagnostic pop)
48 #define OPENVDB_NO_FP_EQUALITY_WARNING_BEGIN
49 #define OPENVDB_NO_FP_EQUALITY_WARNING_END
56 #define OPENVDB_IS_POD(Type) \
57 static_assert(std::is_standard_layout<Type>::value, \
58 #Type" must be a POD type (satisfy StandardLayoutType.)"); \
59 static_assert(std::is_trivial<Type>::value, \
60 #Type" must be a POD type (satisfy TrivialType.)");
70 template<
typename T>
inline constexpr
T zeroVal() {
return T(0); }
72 template<>
inline std::string zeroVal<std::string>() {
return ""; }
89 template<
typename Type1,
typename Type2>
98 template<
typename Type1,
typename Type2>
107 template<
typename Type1,
typename Type2>
119 template <
typename T>
inline constexpr
T pi() {
return 3.141592653589793238462643383279502884e+00; }
120 template <>
inline constexpr
float pi() {
return 3.141592653589793238462643383279502884e+00F; }
121 template <>
inline constexpr
double pi() {
return 3.141592653589793238462643383279502884e+00; }
122 template <>
inline constexpr
long double pi() {
return 3.141592653589793238462643383279502884e+00L; }
131 #if defined(_MSC_VER)
132 #pragma warning(push)
133 #pragma warning(disable:4146)
136 #if defined(_MSC_VER)
155 template<
typename T>
struct Delta {
static T value() {
return zeroVal<T>(); } };
157 template<>
struct Delta<double> {
static double value() {
return 1e-9; } };
165 template<
typename FloatType =
double,
typename EngineType = std::mt19937>
170 std::uniform_real_distribution<FloatType> mRand;
181 Rand01(
unsigned int seed): mEngine(static_cast<typename EngineType::result_type>(seed)) {}
186 mEngine.seed(static_cast<typename EngineType::result_type>(seed));
190 const EngineType&
engine()
const {
return mEngine; }
201 template<
typename IntType =
int,
typename EngineType = std::mt19937>
205 using Distr = std::uniform_int_distribution<IntType>;
215 mRand(std::
min(imin, imax), std::
max(imin, imax))
221 RandInt(
unsigned int seed, IntType imin, IntType imax):
222 mEngine(static_cast<typename EngineType::result_type>(seed)),
223 mRand(std::
min(imin, imax), std::
max(imin, imax))
235 mEngine.seed(static_cast<typename EngineType::result_type>(seed));
239 const EngineType&
engine()
const {
return mEngine; }
249 return mRand(mEngine,
typename Distr::param_type(lo, hi));
259 template<
typename Type>
263 assert( !(min>max) );
264 return x > min ? x < max ? x : max :
min;
269 template<
typename Type>
275 template<
typename Type>
279 if (x >=
Type(0) && x <=
Type(1))
return false;
285 template<
typename Type>
289 return x > 0 ? x < 1 ? (3-2*
x)*x*x :
Type(1) :
Type(0);
294 template<
typename Type>
309 inline int64_t
Abs(int64_t i)
311 static_assert(
sizeof(decltype(
std::abs(i))) ==
sizeof(int64_t),
312 "std::abs(int64) broken");
315 inline float Abs(
float x) {
return std::fabs(x); }
316 inline double Abs(
double x) {
return std::fabs(x); }
317 inline long double Abs(
long double x) {
return std::fabs(x); }
318 inline uint32_t
Abs(uint32_t i) {
return i; }
319 inline uint64_t
Abs(uint64_t i) {
return i; }
320 inline bool Abs(
bool b) {
return b; }
322 template <
typename T>
335 template<
typename Type>
340 return x == zeroVal<Type>();
347 template<
typename Type>
352 return !(x > tolerance) && !(x < -tolerance);
356 template<
typename Type>
360 return !(x > tolerance) && !(x < -tolerance);
365 template<
typename Type>
395 isNan(
const float x) {
return std::isnan(x); }
400 isNan(
const Type&
x) {
return std::isnan(static_cast<double>(x)); }
404 template<
typename Type>
413 template<
typename Type>
421 #define OPENVDB_EXACT_IS_APPROX_EQUAL(T) \
422 template<> inline bool isApproxEqual<T>(const T& a, const T& b) { return a == b; } \
423 template<> inline bool isApproxEqual<T>(const T& a, const T& b, const T&) { return a == b; } \
432 template<typename
Type>
436 return (b - a < tolerance);
441 template<
typename T0,
typename T1>
451 template<
typename Type>
457 if (!(
Abs(a - b) > absTol))
return true;
464 relError =
Abs((a - b) / b);
466 relError =
Abs((a - b) / a);
468 return (relError <= relTol);
482 static_assert(
sizeof(int32_t) ==
sizeof f,
"`float` has an unexpected size.");
484 std::memcpy(&ret, &f,
sizeof(int32_t));
492 static_assert(
sizeof(int64_t) ==
sizeof d,
"`double` has an unexpected size.");
494 std::memcpy(&ret, &d,
sizeof(int64_t));
503 isUlpsEqual(
const double aLeft,
const double aRight,
const int64_t aUnitsInLastPlace)
508 longLeft = INT64_C(0x8000000000000000) - longLeft;
514 longRight = INT64_C(0x8000000000000000) - longRight;
517 int64_t difference =
Abs(longLeft - longRight);
518 return (difference <= aUnitsInLastPlace);
522 isUlpsEqual(
const float aLeft,
const float aRight,
const int32_t aUnitsInLastPlace)
527 intLeft = 0x80000000 - intLeft;
533 intRight = 0x80000000 - intRight;
536 int32_t difference =
Abs(intLeft - intRight);
537 return (difference <= aUnitsInLastPlace);
547 template<
typename Type>
551 template<
typename Type>
555 template<
typename Type>
559 template<
typename Type>
568 while (n--) ans *=
x;
577 assert( b >= 0.0
f &&
"Pow(float,float): base is negative" );
584 assert( b >= 0.0 &&
"Pow(double,double): base is negative" );
593 template<
typename Type>
601 template<
typename Type>
609 template<
typename Type>
617 template<
typename Type>
625 template<
typename Type>
633 template<
typename Type>
642 template<
typename Type>
654 template<
typename Type>
659 template<
typename Type>
664 template<
typename Type>
672 template<
typename Type>
680 template<
typename Type>
688 template<
typename Type>
697 template<
typename Type>
709 template<
typename Type>
735 template <
typename Type>
741 template <
typename Type>
745 return ( (a<zeroVal<Type>()) ^ (b<zeroVal<Type>()) );
751 template <
typename Type>
769 inline float Cbrt(
float x) {
return std::cbrt(x); }
770 inline double Cbrt(
double x) {
return std::cbrt(x); }
771 inline long double Cbrt(
long double x) {
return std::cbrt(x); }
777 inline int Mod(
int x,
int y) {
return (x % y); }
792 template<
typename Type>
797 return remainder ? x-remainder+base :
x;
808 template<
typename Type>
813 return remainder ? x-remainder :
x;
827 template<
typename Type>
833 template<
typename Type>
841 template<
typename Type>
863 template<
typename Type>
868 template<
typename Type>
872 Type tenth =
static_cast<Type>(
Pow(
size_t(10), digits));
892 template<
typename Type>
920 template <
typename S,
typename T>
922 using type =
typename hboost::numeric::conversion_traits<S, T>::supertype;
929 template<
typename Vec3T>
934 for (
size_t i = 1; i < 3; ++i) {
936 if (v[i] <= v[r]) r = i;
945 template<
typename Vec3T>
950 for (
size_t i = 1; i < 3; ++i) {
952 if (v[i] >= v[r]) r = i;
961 #endif // OPENVDB_MATH_MATH_HAS_BEEN_INCLUDED
void setSeed(unsigned int seed)
Set the seed value for the random number generator.
SYS_API double cos(double x)
typedef int(APIENTRYP RE_PFNGLXSWAPINTERVALSGIPROC)(int)
SYS_API double fmod(double x, double y)
Type Inv(Type x)
Return the inverse of x.
Type Truncate(Type x, unsigned int digits)
Return x truncated to the given number of decimal digits.
int Ceil(float x)
Return the ceiling of x.
Simple generator of random numbers over the range [0, 1)
bool cwiseGreaterThan(const Mat< SIZE, T > &m0, const Mat< SIZE, T > &m1)
Type Pow(Type x, int n)
Return xn.
Type IntegerPart(Type x)
Return the integer part of x.
bool ZeroCrossing(const Type &a, const Type &b)
Return true if the interval [a, b] includes zero, i.e., if either a or b is zero or if they have diff...
bool isExactlyEqual(const T0 &a, const T1 &b)
Return true if a is exactly equal to b.
Type Pow2(Type x)
Return x2.
IMATH_HOSTDEVICE constexpr int floor(T x) IMATH_NOEXCEPT
T negative(const T &val)
Return the unary negation of the given value.
size_t MaxIndex(const Vec3T &v)
Return the index [0,1,2] of the largest value in a 3D vector.
GLsizei const GLchar *const * string
Type FractionalPart(Type x)
Return the fractional part of x.
GLsizei const GLfloat * value
Mat3< Type1 > cwiseAdd(const Mat3< Type1 > &m, const Type2 s)
vfloat4 sqrt(const vfloat4 &a)
GLboolean GLboolean GLboolean GLboolean a
#define OPENVDB_USE_VERSION_NAMESPACE
const EngineType & engine() const
Return a const reference to the random number generator.
float Cos(const float &x)
Return cos x.
SYS_API float powf(float x, float y)
ImageBuf OIIO_API min(Image_or_Const A, Image_or_Const B, ROI roi={}, int nthreads=0)
Rand01(unsigned int seed)
Initialize the generator.
bool SignChange(const Type &a, const Type &b)
Return true if a and b have different signs.
float RoundDown(float x)
Return x rounded down to the nearest integer.
RandInt(const EngineType &engine, IntType imin, IntType imax)
Initialize the generator.
bool isNegative(const Type &x)
Return true if x is less than zero.
Tolerance for floating-point comparison.
float RoundUp(float x)
Return x rounded up to the nearest integer.
float Cbrt(float x)
Return the cube root of a floating-point value.
Simple random integer generator.
ImageBuf OIIO_API pow(const ImageBuf &A, cspan< float > B, ROI roi={}, int nthreads=0)
constexpr T zeroVal()
Return the value of type T that corresponds to zero.
bool isNegative< bool >(const bool &)
size_t MinIndex(const Vec3T &v)
Return the index [0,1,2] of the smallest value in a 3D vector.
bool isApproxEqual(const Type &a, const Type &b, const Type &tolerance)
Return true if a is equal to b to within the given tolerance.
IMATH_NAMESPACE::V2f float
Coord Abs(const Coord &xyz)
float Round(float x)
Return x rounded to the nearest integer.
bool isInfinite(const float x)
Return true if x is an infinity value (either positive infinity or negative infinity).
Type Pow4(Type x)
Return x4.
Delta for small floating-point offsets.
float Sqrt(float x)
Return the square root of a floating-point value.
bool isNan(const float x)
Return true if x is a NaN (Not-A-Number) value.
Type Pow3(Type x)
Return x3.
bool cwiseLessThan(const Mat< SIZE, T > &m0, const Mat< SIZE, T > &m1)
bool isRelOrApproxEqual(const Type &a, const Type &b, const Type &absTol, const Type &relTol)
#define OPENVDB_NO_FP_EQUALITY_WARNING_BEGIN
bool isUlpsEqual(const double aLeft, const double aRight, const int64_t aUnitsInLastPlace)
bool isApproxZero(const Type &x)
Return true if x is equal to zero to within the default floating-point comparison tolerance...
GLboolean GLboolean GLboolean b
Type Clamp(Type x, Type min, Type max)
Return x clamped to [min, max].
#define OPENVDB_EXACT_IS_APPROX_EQUAL(T)
RandInt(unsigned int seed, IntType imin, IntType imax)
Initialize the generator.
GLfloat GLfloat GLfloat GLfloat h
IMATH_HOSTDEVICE constexpr int ceil(T x) IMATH_NOEXCEPT
int Sign(const Type &x)
Return the sign of the given value as an integer (either -1, 0 or 1).
Library and file format version numbers.
void setSeed(unsigned int seed)
Set the seed value for the random number generator.
int32_t floatToInt32(const float f)
int64_t doubleToInt64(const double d)
ImageBuf OIIO_API max(Image_or_Const A, Image_or_Const B, ROI roi={}, int nthreads=0)
const Type & Min(const Type &a, const Type &b)
Return the minimum of two values.
const EngineType & engine() const
Return a const reference to the random number generator.
Type Chop(Type x, Type delta)
Return x if it is greater or equal in magnitude than delta. Otherwise, return zero.
constexpr T pi()
Pi constant taken from Boost to match old behaviour.
Type EuclideanRemainder(Type x)
Vec3< typename promote< T, typename Coord::ValueType >::type > operator+(const Vec3< T > &v0, const Coord &v1)
Allow a Coord to be added to or subtracted from a Vec3.
int Floor(float x)
Return the floor of x.
bool ClampTest01(Type &x)
Return true if x is outside [0,1].
IMATH_INTERNAL_NAMESPACE_HEADER_ENTER IMATH_HOSTDEVICE constexpr T abs(T a) IMATH_NOEXCEPT
constexpr bool zeroVal< bool >()
Return the bool value that corresponds to zero.
IntType operator()()
Return a randomly-generated integer in the current range.
float Sin(const float &x)
Return sin x.
Rand01(const EngineType &engine)
Initialize the generator.
Type SmoothUnitStep(Type x)
Return 0 if x < 0, 1 if x > 1 or else (3 − 2 x) x .
void setRange(IntType imin, IntType imax)
Change the range over which integers are distributed to [imin, imax].
#define OPENVDB_VERSION_NAME
The version namespace name for this library version.
Type Remainder(Type x, Type y)
Return the remainder of x / y.
const Type & Max(const Type &a, const Type &b)
Return the maximum of two values.
SYS_API double sin(double x)
int Mod(int x, int y)
Return the remainder of x / y.
auto PrintCast(const T &val) -> typename std::enable_if<!std::is_same< T, int8_t >::value &&!std::is_same< T, uint8_t >::value, const T & >::type
8-bit integer values print to std::ostreams as characters. Cast them so that they print as integers i...
bool isZero(const Type &x)
Return true if x is exactly equal to zero.
bool isFinite(const float x)
Return true if x is finite.
Type Exp(const Type &x)
Return ex.
IntType operator()(IntType imin, IntType imax)
Return a randomly-generated integer in the new range [imin, imax], without changing the current range...
FloatType operator()()
Return a uniformly distributed random number in the range [0, 1).
Type Clamp01(Type x)
Return x clamped to [0, 1].
#define OPENVDB_NO_FP_EQUALITY_WARNING_END
bool isApproxLarger(const Type &a, const Type &b, const Type &tolerance)
Return true if a is larger than b to within the given tolerance, i.e., if b - a < tolerance...