|
|
@ -161,10 +161,10 @@ namespace detail |
|
|
|
{ |
|
|
|
{ |
|
|
|
static vec<4, float, Q> call(qua<float, Q> const& q, vec<4, float, Q> const& v) |
|
|
|
static vec<4, float, Q> call(qua<float, Q> const& q, vec<4, float, Q> const& v) |
|
|
|
{ |
|
|
|
{ |
|
|
|
# ifdef GLM_FORCE_QUAT_DATA_XYZW |
|
|
|
# ifdef GLM_FORCE_QUAT_DATA_WXYZ |
|
|
|
__m128 const q_wwww = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(3, 3, 3, 3)); |
|
|
|
__m128 const q_wwww = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(0, 0, 0, 0)); |
|
|
|
__m128 const q_swp0 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(3, 0, 2, 1)); |
|
|
|
__m128 const q_swp0 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(0, 1, 3, 2)); |
|
|
|
__m128 const q_swp1 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(3, 1, 0, 2)); |
|
|
|
__m128 const q_swp1 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(0, 2, 1, 3)); |
|
|
|
__m128 const v_swp0 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 0, 2, 1)); |
|
|
|
__m128 const v_swp0 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 0, 2, 1)); |
|
|
|
__m128 const v_swp1 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 1, 0, 2)); |
|
|
|
__m128 const v_swp1 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 1, 0, 2)); |
|
|
|
|
|
|
|
|
|
|
@ -181,9 +181,9 @@ namespace detail |
|
|
|
Result.data = _mm_add_ps(v.data, _mm_add_ps(uv, uuv)); |
|
|
|
Result.data = _mm_add_ps(v.data, _mm_add_ps(uv, uuv)); |
|
|
|
return Result; |
|
|
|
return Result; |
|
|
|
# else |
|
|
|
# else |
|
|
|
__m128 const q_wwww = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(0, 0, 0, 0)); |
|
|
|
__m128 const q_wwww = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(3, 3, 3, 3)); |
|
|
|
__m128 const q_swp0 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(0, 1, 3, 2)); |
|
|
|
__m128 const q_swp0 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(3, 0, 2, 1)); |
|
|
|
__m128 const q_swp1 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(0, 2, 1, 3)); |
|
|
|
__m128 const q_swp1 = _mm_shuffle_ps(q.data, q.data, _MM_SHUFFLE(3, 1, 0, 2)); |
|
|
|
__m128 const v_swp0 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 0, 2, 1)); |
|
|
|
__m128 const v_swp0 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 0, 2, 1)); |
|
|
|
__m128 const v_swp1 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 1, 0, 2)); |
|
|
|
__m128 const v_swp1 = _mm_shuffle_ps(v.data, v.data, _MM_SHUFFLE(3, 1, 0, 2)); |
|
|
|
|
|
|
|
|
|
|
|