aboutsummaryrefslogtreecommitdiff
path: root/src/libjin/Math/je_math.h
blob: de57e367b274059ddf8c148da05580b17402244c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#ifndef __JE_UTILS_MATH_H__
#define __JE_UTILS_MATH_H__

#include "je_constant.h"
#include "je_matrix.h"
#include "je_quad.h"

namespace JinEngine
{
	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;
		}
    
		template<typename T>
		inline T lerp(T a, T b, float t)
		{
			return a + t * (b - a);
		}

        inline float lerp(float a, float b, float f)
        {
            f = clamp<float>(f, 0, 1);
            return a + f * (b - a);
        }

	} // namespace Math
} // namespace JinEngine

#endif // __JE_UTILS_MATH_H__