5 template<
typename genType>
6 GLM_FUNC_QUALIFIER genType
angle
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)));
16 template<length_t L,
typename T, qualifier Q>
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)));
24 template<
typename T, qualifier Q>
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))));
36 template<
typename T, qualifier Q>
39 GLM_STATIC_ASSERT(std::numeric_limits<T>::is_iec559,
"'orientedAngle' only accept floating-point inputs");
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));
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 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