aboutsummaryrefslogtreecommitdiff
path: root/src/libjin/Math/Math.h
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2018-07-28 22:10:27 +0800
committerchai <chaifix@163.com>2018-07-28 22:10:27 +0800
commit52693d68f7181d707e1a192d67a617145b358394 (patch)
tree5a39bcdf225def306738ead6683cd224e2c5762d /src/libjin/Math/Math.h
parentd033400614e7e2c0ff49e5100c81e937e5818e74 (diff)
*update
Diffstat (limited to 'src/libjin/Math/Math.h')
-rw-r--r--src/libjin/Math/Math.h69
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