23#if GLM_MESSAGES == GLM_ENABLE && !defined(GLM_EXT_INCLUDED)
24# ifndef GLM_ENABLE_EXPERIMENTAL
25# pragma message("GLM: GLM_GTX_dual_quaternion is an experimental extension and may change in the future. Use #define GLM_ENABLE_EXPERIMENTAL before including it, if you really want to use it.")
27# pragma message("GLM: GLM_GTX_dual_quaternion extension included")
36 template<
typename T, qualifier Q = defaultp>
50 typedef length_t length_type;
52 GLM_FUNC_DECL
static GLM_CONSTEXPR length_type
length(){
return 2;}
54 GLM_FUNC_DECL part_type & operator[](length_type i);
55 GLM_FUNC_DECL part_type
const& operator[](length_type i)
const;
59 GLM_FUNC_DECL GLM_CONSTEXPR
tdualquat() GLM_DEFAULT;
66 GLM_FUNC_DECL GLM_CONSTEXPR
tdualquat(
qua<T, Q> const& real);
68 GLM_FUNC_DECL GLM_CONSTEXPR
tdualquat(
qua<T, Q> const& real,
qua<T, Q> const& dual);
75 GLM_FUNC_DECL GLM_EXPLICIT GLM_CONSTEXPR
tdualquat(
mat<2, 4, T, Q> const& holder_mat);
76 GLM_FUNC_DECL GLM_EXPLICIT GLM_CONSTEXPR
tdualquat(
mat<3, 4, T, Q> const& aug_mat);
85 GLM_FUNC_DECL
tdualquat<T, Q> & operator*=(U s);
87 GLM_FUNC_DECL
tdualquat<T, Q> & operator/=(U s);
107 GLM_FUNC_DECL
vec<3, T, Q> operator*(
tdualquat<T, Q> const& q,
vec<3, T, Q> const& v);
110 GLM_FUNC_DECL
vec<3, T, Q> operator*(
vec<3, T, Q> const& v,
tdualquat<T, Q> const& q);
113 GLM_FUNC_DECL
vec<4, T, Q> operator*(
tdualquat<T, Q> const& q,
vec<4, T, Q> const& v);
116 GLM_FUNC_DECL
vec<4, T, Q> operator*(
vec<4, T, Q> const& v,
tdualquat<T, Q> const& q);
232#if(!defined(GLM_PRECISION_HIGHP_FLOAT) && !defined(GLM_PRECISION_MEDIUMP_FLOAT) && !defined(GLM_PRECISION_LOWP_FLOAT))
242#elif(defined(GLM_PRECISION_HIGHP_FLOAT) && !defined(GLM_PRECISION_MEDIUMP_FLOAT) && !defined(GLM_PRECISION_LOWP_FLOAT))
245#elif(!defined(GLM_PRECISION_HIGHP_FLOAT) && defined(GLM_PRECISION_MEDIUMP_FLOAT) && !defined(GLM_PRECISION_LOWP_FLOAT))
248#elif(!defined(GLM_PRECISION_HIGHP_FLOAT) && !defined(GLM_PRECISION_MEDIUMP_FLOAT) && defined(GLM_PRECISION_LOWP_FLOAT))
252# error "GLM error: multiple default precision requested for single-precision floating-point types"
256#if(!defined(GLM_PRECISION_HIGHP_DOUBLE) && !defined(GLM_PRECISION_MEDIUMP_DOUBLE) && !defined(GLM_PRECISION_LOWP_DOUBLE))
261#elif(defined(GLM_PRECISION_HIGHP_DOUBLE) && !defined(GLM_PRECISION_MEDIUMP_DOUBLE) && !defined(GLM_PRECISION_LOWP_DOUBLE))
263#elif(!defined(GLM_PRECISION_HIGHP_DOUBLE) && defined(GLM_PRECISION_MEDIUMP_DOUBLE) && !defined(GLM_PRECISION_LOWP_DOUBLE))
265#elif(!defined(GLM_PRECISION_HIGHP_DOUBLE) && !defined(GLM_PRECISION_MEDIUMP_DOUBLE) && defined(GLM_PRECISION_LOWP_DOUBLE))
268# error "GLM error: Multiple default precision requested for double-precision floating-point types"
274#include "dual_quaternion.inl"
GLM_FUNC_QUALIFIER vec< L, T, Q > normalize(vec< L, T, Q > const &x)
Definition func_geometric.inl:190
GLM_FUNC_QUALIFIER mat< C, R, T, Q > inverse(mat< C, R, T, Q > const &m)
Definition func_matrix.inl:388
GLM_FUNC_DECL qua< T, Q > lerp(qua< T, Q > const &x, qua< T, Q > const &y, T a)
Definition quaternion_common.inl:29
highp_fdualquat dualquat
Definition dual_quaternion.hpp:236
highp_ddualquat ddualquat
Definition dual_quaternion.hpp:260
GLM_FUNC_DECL tdualquat< T, Q > dual_quat_identity()
Definition dual_quaternion.inl:219
highp_fdualquat fdualquat
Definition dual_quaternion.hpp:241
GLM_FUNC_DECL mat< 2, 4, T, Q > mat2x4_cast(tdualquat< T, Q > const &x)
Definition dual_quaternion.inl:253
GLM_FUNC_DECL tdualquat< T, Q > dualquat_cast(mat< 2, 4, T, Q > const &x)
Definition dual_quaternion.inl:295
GLM_FUNC_DECL mat< 3, 4, T, Q > mat3x4_cast(tdualquat< T, Q > const &x)
Definition dual_quaternion.inl:259
GLM_FUNC_DECL mat< 4, 4, T, Q > orientation(vec< 3, T, Q > const &Normal, vec< 3, T, Q > const &Up)
Definition rotate_vector.inl:174
Core features
Definition common.hpp:21
qualifier
Qualify GLM types in term of alignment (packed, aligned) and precision in term of ULPs (lowp,...
Definition qualifier.hpp:9
@ mediump
By default mediump qualifier is also packed.
Definition qualifier.hpp:22
@ highp
By default highp qualifier is also packed.
Definition qualifier.hpp:21
@ lowp
By default lowp qualifier is also packed.
Definition qualifier.hpp:23
Definition qualifier.hpp:36
Definition type_quat.hpp:20
Definition dual_quaternion.hpp:38
static GLM_FUNC_DECL GLM_CONSTEXPR length_type length()
Return the count of components of a dual quaternion.
Definition dual_quaternion.hpp:52
Definition qualifier.hpp:35