diff options
author | chai <chaifix@163.com> | 2018-07-28 22:10:27 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2018-07-28 22:10:27 +0800 |
commit | 52693d68f7181d707e1a192d67a617145b358394 (patch) | |
tree | 5a39bcdf225def306738ead6683cd224e2c5762d /src/libjin/Math/Math.h | |
parent | d033400614e7e2c0ff49e5100c81e937e5818e74 (diff) |
*update
Diffstat (limited to 'src/libjin/Math/Math.h')
-rw-r--r-- | src/libjin/Math/Math.h | 69 |
1 files changed, 62 insertions, 7 deletions
diff --git a/src/libjin/Math/Math.h b/src/libjin/Math/Math.h index 849f74b..5b34f4c 100644 --- a/src/libjin/Math/Math.h +++ b/src/libjin/Math/Math.h @@ -1,16 +1,71 @@ #ifndef __JIN_UTILS_MATH_H #define __JIN_UTILS_MATH_H -#include <math.h> - #include "constant.h" #include "matrix.h" #include "quad.h" -#define min(a,b) (a < b ? a : b) -#define max(a,b) (a > b ? a : b) -#define clamp(a, mi,ma) (min(max(a,mi),ma)) -#define within(a,min,max) (a >= min && a <= max) -#define without(a,min,max) (a < min || a > max) +namespace jin +{ +namespace math +{ + +#ifdef min +#undef min +#endif // min +#ifdef max +#undef max +#endif // max + + template<typename T> + inline T min(T a, T b) + { + return a < b ? a : b; + } + + template<typename T> + inline T max(T a, T b) + { + return a > b ? a : b; + } + + template<typename T> + inline T clamp(T a, T mi, T ma) + { + return min<T>(max<T>(a, mi), ma); + } + + template<typename T> + inline bool within(T a, T mi, T ma) + { + return a >= mi && a <= ma; + } + + template<typename T> + inline bool without(T a, T mi, T ma) + { + return a < mi || a > ma; + } + + template<typename T> + inline T abs(T a) + { + return a > 0 ? a : -a; + } + + template<typename T> + inline T lowerBound(T a, T lower) + { + return a < lower ? lower : a; + } + + template<typename T> + inline T upperBound(T a, T upper) + { + return a > upper ? upper : a; + } + +} +} #endif
\ No newline at end of file |