Clutter Engine 0.0.1
Loading...
Searching...
No Matches
vector_angle.inl
1
2
3namespace glm
4{
5 template<typename genType>
6 GLM_FUNC_QUALIFIER genType angle
7 (
8 genType const& x,
9 genType const& y
10 )
11 {
12 GLM_STATIC_ASSERT(std::numeric_limits<genType>::is_iec559, "'angle' only accept floating-point inputs");
13 return acos(clamp(dot(x, y), genType(-1), genType(1)));
14 }
15
16 template<length_t L, typename T, qualifier Q>
17 GLM_FUNC_QUALIFIER T angle(vec<L, T, Q> const& x, vec<L, T, Q> const& y)
18 {
19 GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'angle' only accept floating-point inputs");
20 return acos(clamp(dot(x, y), T(-1), T(1)));
21 }
22
24 template<typename T, qualifier Q>
25 GLM_FUNC_QUALIFIER T orientedAngle(vec<2, T, Q> const& x, vec<2, T, Q> const& y)
26 {
27 GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'orientedAngle' only accept floating-point inputs");
28 T const Angle(acos(clamp(dot(x, y), T(-1), T(1))));
29
30 if(all(epsilonEqual(y, glm::rotate(x, Angle), T(0.0001))))
31 return Angle;
32 else
33 return -Angle;
34 }
35
36 template<typename T, qualifier Q>
37 GLM_FUNC_QUALIFIER T orientedAngle(vec<3, T, Q> const& x, vec<3, T, Q> const& y, vec<3, T, Q> const& ref)
38 {
39 GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559, "'orientedAngle' only accept floating-point inputs");
40
41 T const Angle(acos(clamp(dot(x, y), T(-1), T(1))));
42 return mix(Angle, -Angle, dot(ref, cross(x, y)) < T(0));
43 }
44}//namespace glm
GLM_FUNC_DECL genTypeT mix(genTypeT x, genTypeT y, genTypeU a)
Definition func_common.inl:526
GLM_FUNC_QUALIFIER vec< 3, T, Q > cross(vec< 3, T, Q > const &x, vec< 3, T, Q > const &y)
Definition func_geometric.inl:175
GLM_FUNC_QUALIFIER vec< L, T, Q > acos(vec< L, T, Q > const &v)
Definition func_trigonometric.inl:77
GLM_FUNC_QUALIFIER GLM_CONSTEXPR bool all(vec< L, bool, Q > const &v)
Definition func_vector_relational.inl:67
GLM_FUNC_DECL mat< 4, 4, T, Q > rotate(mat< 4, 4, T, Q > const &m, T angle, vec< 3, T, Q > const &axis)
Definition matrix_transform.inl:18
GLM_FUNC_DECL T angle(qua< T, Q > const &x)
Definition quaternion_trigonometric.inl:6
GLM_FUNC_DECL vec< L, bool, Q > epsilonEqual(vec< L, T, Q > const &x, vec< L, T, Q > const &y, T const &epsilon)
Definition epsilon.inl:32
GLM_FUNC_DECL T orientedAngle(vec< 2, T, Q > const &x, vec< 2, T, Q > const &y)
Definition vector_angle.inl:25
Core features
Definition common.hpp:21
Definition qualifier.hpp:35