glm/test/main.cpp
Christophe Riccio bc877da307 Added test files
2010-04-14 13:25:41 +01:00

2314 lines
57 KiB
C++

///////////////////////////////////////////////////////////////////////////////////////////////////
// OpenGL Mathematics Copyright (c) 2005 - 2010 G-Truc Creation (www.g-truc.net)
///////////////////////////////////////////////////////////////////////////////////////////////////
// Created : 2005-01-12
// Updated : 2006-12-03
// Licence : This source is under MIT License
// File : main.cpp
///////////////////////////////////////////////////////////////////////////////////////////////////
#include "precompiled.hpp"
#include <glm/gtc/matrix_operation.hpp>
#include <glm/gtx/simd_vec4.hpp>
#include <glm/core/intrinsic_common.hpp>
#include <glm/core/intrinsic_exponential.hpp>
#include <glm/core/intrinsic_geometric.hpp>
#include <glm/core/intrinsic_matrix.hpp>
#include <glm/core/intrinsic_trigonometric.hpp>
#include <glm/core/intrinsic_vector_relational.hpp>
#include <glm/gtc/matrix_transform.hpp>
#include <glm/gtc/matrix_projection.hpp>
#include <glm/gtc/quaternion.hpp>
#include <glm/gtx/bit.hpp>
#include <glm/gtx/inverse.hpp>
#include <glm/gtx/inverse_transpose.hpp>
#include <glm/gtx/fast_square_root.hpp>
#include <glm/gtx/string_cast.hpp>
#include <glm/gtx/intersect.hpp>
#include <glm/gtx/matrix_operation.hpp>
#include <glm/gtx/integer.hpp>
#include <glm/gtx/random.hpp>
#include <glm/gtx/color_cast.hpp>
#include <glm/gtx/transform2.hpp>
#include <glm/gtx/gradient_paint.hpp>
#include <glm/gtx/perpendicular.hpp>
#include <glm/gtx/vector_angle.hpp>
#include <glm/gtx/rotate_vector.hpp>
#include "core.hpp"
#include "img.hpp"
#include "gtc.hpp"
#include "gtx.hpp"
#include <vector>
//namespace glm
//{
// using GLM_GTX_double_float;
// using GLM_GTX_inverse;
// using GLM_GTX_integer;
// using GLM_GTX_unsigned_int;
//using GLM_GTX_bit;
// using GLM_GTX_fast_square_root;
// using GLM_GTX_number_precision;
// using GLM_GTX_color_cast;
// using GLM_GTX_quaternion;
// using GLM_GTX_inverse_transpose;
// using GLM_GTX_transform;
// using GLM_GTX_transform2;
// using GLM_GTX_intersect;
// using GLM_GTX_random;
// using GLM_GTX_gradient_paint;
// using GLM_GTX_perpendicular;
//using GLM_GTX_compatibility;
//using GLM_GTX_quaternion;
//using GLM_GTX_string_cast;
//using GLM_GTX_fast_square_root;
//using GLM_GTX_half_float;
//using GLM_GTX_vector_angle;
//using GLM_GTX_matrix_projection;
//}
unsigned int GetCpuCycle()
{
unsigned int LowWord = 0;
unsigned int HighWord = 0;
// _asm
// {
// cpuid
// // Insert Real Time Stamp Counter opcodes
// _emit 0x0F
// _emit 0x31
// mov HighWord, edx
// mov LowWord, eax
// }
// return ((__int64)(HighWord) << 32) + LowWord;
return 0;
}
//namespace wip
//{
// inline glm::detail::fvec4SIMD rcp(glm::detail::fvec4SIMD const & v)
// {
// return glm::detail::fvec4SIMD(_mm_rcp_ps(v.Data));
// }
//
// inline glm::detail::fvec4SIMD sqrt(glm::detail::fvec4SIMD const & v)
// {
// return glm::detail::fvec4SIMD(_mm_sqrt_ps(v.Data));
// }
//
// inline glm::detail::fvec4SIMD inversesqrt(glm::detail::fvec4SIMD const & v)
// {
// return glm::detail::fvec4SIMD(_mm_rsqrt_ps(v.Data));
// }
//
// inline glm::detail::fvec4SIMD min(glm::detail::fvec4SIMD const & v1, glm::detail::fvec4SIMD const & v2)
// {
// return glm::detail::fvec4SIMD(_mm_min_ps(v1.Data, v2.Data));
// }
//
// inline glm::detail::fvec4SIMD max(glm::detail::fvec4SIMD const & v1, glm::detail::fvec4SIMD const & v2)
// {
// return glm::detail::fvec4SIMD(_mm_max_ps(v1.Data, v2.Data));
// }
//}//namespace wip
void test_simd()
{
glm::detail::fvec4SIMD v1(1.0f, 2.0f, 3.0f, 4.0f);
glm::detail::fvec4SIMD v2(5.0f, 6.0f, 7.0f, 8.0f);
bool end = true;
}
namespace a
{
namespace b{}
}
namespace c = a::b;
//#include <glm/ext/virtrev/gl.hpp>
#include <cstdio>
#include <cstdlib>
#include <ctime>
//#include <windows.hpp>
//#include <boost/static_assert.hpp>
#ifdef min
#undef min
#endif
#ifdef max
#undef max
#endif
//#include "test/sse_vec4.h"
//#include "test/sse_mat4.h"
/*
inline float fastExp0(float x)
{
return 1.0f + x + (x * x * 0.5f) + (x * x * x * 0.1666666667f) + (x * x * x * x * 0.041666667f) + (x * x * x * x * x * 0.008333333333f) + (x * x * x * x * x * x * 0.00138888888888f) + (x * x * x * x * x * x * x * 0.000198412698f) + (x * x * x * x * x * x * x * x * 0.0000248015873f);
}
inline float fastExp1(float x)
{
float x2 = x * x;
float x3 = x2 * x;
float x4 = x3 * x;
float x5 = x4 * x;
float x6 = x5 * x;
float x7 = x6 * x;
float x8 = x7 * x;
return 1.0f + x + (x2 * 0.5f) + (x3 * 0.1666666667f) + (x4 * 0.041666667f) + (x5 * 0.008333333333f) + (x6 * 0.00138888888888f) + (x7 * 0.000198412698f) + (x8 * 0.0000248015873f);
}
inline float fastExp2(float x)
{
float x2 = x * x;
float x3 = x2 * x;
float x4 = x3 * x;
float x5 = x4 * x;
return 1.0f + x + (x2 * 0.5f) + (x3 * 0.1666666667f) + (x4 * 0.041666667f) + (x5 * 0.008333333333f);
}
inline float fastExp3(float x)
{
return 1.0f + x * (1.0f + x * 0.5f * (1.0f + x * 0.3333333333f * (1.0f + x * 0.25 * (1.0f + x * 0.2f))));
}
inline float fastExp4(float x)
{
if(x >= 0.0f && x <= 1.0f)
{
float x2 = x * x;
float x3 = x2 * x;
float x4 = x3 * x;
float x5 = x4 * x;
return 1.0f + x + (x2 * 0.5f) + (x3 * 0.1666666667f) + (x4 * 0.041666667f) + (x5 * 0.008333333333f);
}
else
{
float e = 2.718281828f;
float IntegerPart = glm::floor(x);
float FloatPart = x - IntegerPart;
float z = e;
for(int i = 1; i < int(IntegerPart); ++i)
z *= e;
float x2 = FloatPart * FloatPart;
float x3 = x2 * FloatPart;
float x4 = x3 * FloatPart;
float x5 = x4 * FloatPart;
return z * (1.0f + FloatPart + (x2 * 0.5f) + (x3 * 0.1666666667f) + (x4 * 0.041666667f) + (x5 * 0.008333333333f));
}
}
__forceinline float fastExp5(float x)
{
const float e = 2.718281828f;
const float IntegerPart = glm::floor(x);
const float FloatPart = x - IntegerPart;
float z = 1.f;
//for(int i = 0; i < int(IntegerPart); ++i)
// z *= e;
const float x2 = FloatPart * FloatPart;
const float x3 = x2 * FloatPart;
const float x4 = x3 * FloatPart;
const float x5 = x4 * FloatPart;
return z * (1.0f + FloatPart + (x2 * 0.5f) + (x3 * 0.1666666667f) + (x4 * 0.041666667f) + (x5 * 0.008333333333f));
}
inline float fastLn0(float x)
{
float y1 = (x - 1.0f) / (x + 1.0f);
float y2 = y1 * y1;
float y4 = y2 * y2;
float y6 = y4 * y2;
float y8 = y4 * y4;
return 2.0f * y1 * (1.0f + y2 * 0.3333333333f + y4 * 0.2f + y6 * 0.1428571429f);// + y8 * 0.1111111111f);
}
inline float fastLn1(float x)
{
float y1 = (x - 1.0f) / (x + 1.0f);
float y2 = y1 * y1;
return 2.0f * y1 * (1.0f + y2 * (0.3333333333f + y2 * (0.2f + y2 * 0.1428571429f)));
}
*/
using namespace std;
using namespace glm;
void subtitiution()
{
//--------------------------------------------------------------------
//AX=B
mat4 L(0.f);
mat4 U(0.f);
mat4 A = mat4(
vec4(4.f),
vec4(4.f),
vec4(4.f),
vec4(4.f));
for(int i=0;i < 4;i++)
for(int j=0;j < 4;j++)
{
if(i>j)
U[i][j]=0;
else if(i==j)
L[i][j]=1;
else
L[i][j]=0;
}
printf("A:\n");
for(int j = 0; j < 4; ++j)
{
printf("(");
for(int i = 0; i < 4; ++i)
printf("%f ", A[j][i]);
printf(")\n");
}
printf("\n");
//Decomposition of A into L and U
for(int i = 0; i < 4; ++i)
for(int j = 0; j < 4; ++j)
{
float Sum = 0.f;
if(i <= j)
{
for(int k = 0; k < 4; ++k)
if(k != i)
Sum += L[i][k] * U[k][j];
U[i][j] = (A[i][j] - Sum);// / U[j][j];
}
else
{
for(int k = 0; k < 4; k++)
if(k != j)
Sum += L[i][k] * U[k][j];
L[i][j] = (A[i][j] - Sum) / U[j][j];
}
}
printf("L:\n");
for(int j = 0; j < 4; ++j)
{
printf("(");
for(int i = 0; i < 4; ++i)
printf("%f ", L[j][i]);
printf(")\n");
}
printf("\n");
printf("U:\n");
for(int j = 0; j < 4; ++j)
{
printf("(");
for(int i = 0; i < 4; ++i)
printf("%f ", U[j][i]);
printf(")\n");
}
printf("\n");
system("pause");
}
void LUDecompsition(
const detail::tmat4x4<float>& m,
detail::tmat4x4<float>& l,
detail::tmat4x4<float>& u)
{
for(int i = 0; i < 4; ++i)
l[i][i] = 1.f;
for(int j = 0; j < 4; ++j)
{
//for(int i = 0; i <= j; ++i)
for(int i = 0; i < j; ++i)
{
u[j][i] = m[j][i];
for(int k = 0; k < i - 1; ++k)
//for(int k = 0; k < i; ++k)
u[j][i] -= l[k][i] * u[j][k];
}
//for(int i = j + 1; i < 4; ++i)
for(int i = j; i < 4; ++i)
{
l[j][i] = m[j][i];
for(int k = 0; k < j - 1; ++k)
//for(int k = 0; k < j; ++k)
l[j][i] -= l[k][i] * u[j][k];
}
}
}
/*
ivec3& operator+=(const ivec3& v, const int s)
{
ivec3 Result = v;
Result.x &= s;
Result.y &= s;
Result.z &= s;
return Result;
}
*/
void g()
{
mat4 m = glm::inverse(mat4(4.0f));
}
void test_gtx_bit()
{
int Number1 = 76;
int NumberA = glm::highestBit(Number1);
int NumberB = glm::highestBitValue(Number1);
bool NumberC = glm::isPowerOfTwo(Number1);
int NumberD = glm::powerOfTwoAbove(Number1);
int NumberE = glm::powerOfTwoBelow(Number1);
int NumberF = glm::powerOfTwoNearest(Number1);
int Number2 = 256;
int NumberG = glm::highestBit(Number2);
int NumberH = glm::highestBitValue(Number2);
bool NumberI = glm::isPowerOfTwo(Number2);
int NumberJ = glm::powerOfTwoAbove(Number2);
int NumberK = glm::powerOfTwoBelow(Number2);
int NumberL = glm::powerOfTwoNearest(Number2);
int NumberZ = 0;
}
/*
struct gni
{
void constructor(short i)
{
data = i;
}
gni& assignement(const gni& i)
{
data = i.data;
return *this;
}
short data;
}
union pouet
{
pouet(detail::thalf x, detail::thalf y, detail::thalf z) :
x(x), y(y), z(z)
{}
struct{detail::thalf x, y, z;};
struct{detail::thalf r, g, b;};
struct{detail::thalf s, t, q;};
};
*/
//#include GLM_EXTENSION(GLM_GTX_compatibility, glm::required);
vec4 mix_fpu(const vec4& x, const vec4& y, const vec4& a)
{
return x * (vec4(1) - a) + y * a;
}
/*
namespace glm
{
template<class T, int N>
struct traits
{
typedef T value_type;
typedef T* pointer;
typedef T& reference;
typedef std::size_t size_type;
static const size_type value_size;
};
template<class T, int N>
static const traits::size_type traits::value_size = N;
template<class Type>
struct traits<Type*>
{
typedef Type value_type;
typedef Type* pointer;
typedef Type& reference;
};
template<class Type>
struct traits<const Type*>
{
typedef Type value_type;
typedef const Type* pointer;
typedef const Type& reference;
};
}
*/
vec2 reference_swizzle(const vec3& a, const vec3& b)
{
return vec2(0.0f);
}
//void test_random()
//{
// float Value = gaussRand1GTX(1.0f, 2.0f);
// detail::_xvecxGTX<8, float> vecN;
// vecN = compRandGTX(vecN, vecN);
//}
void test_matrix()
{
// glm::mat4 Transform = glm::translateGTX(
// glm::rotateGTX(45.f, glm::core::func_geometric::normalize(glm::vec3(1))), glm::vec3(1, 2, 3));
glm::vec3 Normalized = glm::normalize(glm::vec3(1));
glm::mat4 Transform = glm::gtc::matrix_transform::translate(
glm::gtc::matrix_transform::rotate(glm::mat4(1.0f), 45.f, Normalized),
glm::vec3(1, 2, 3));
glm::mat4 TransformA = glm::inverse(Transform);
glm::mat4 TransformB = glm::affineInverse(Transform);
glm::mat4 End;
}
void test_vec4()
{
{
glm::vec4 v(1.0);
glm::vec4 const* const pv = &v;
glm::vec4 const& rv = v;
//float const* pointer1 = &v;
//float const* pointer2 = v;
//float const* pointer3 = pv;
//float const* pointer4 = &rv;
//glm::vec4* p = &v;
//glm::vec4 v6 = v + long(3);
float const* pointer1 = &v[0];
}
//{
// glm::mat4 m;
// glm::mat4 const* const pm = &m;
// glm::mat4 const& rm = m;
// float const* pointer1 = &m;
// float const* pointer2 = m;
// float const* pointer3 = pm;
// float const* pointer4 = &rm;
//}
}
void test_mat4(const glm::mat4& m)
{
//glm::mat4 copy = m;
//glLoadMatrix(GL_MODELVIEW, copy);
}
void test_string_cast()
{
printf("Test string cast: %s\n", glm::string(glm::vec4(1, 2, 3, 4)).c_str());
}
void test_isPowerOfTwo()
{
bool resultA = glm::isPowerOfTwo(unsigned(512));
bool resultB = glm::isPowerOfTwo(unsigned(513));
bool end = true;
}
//#include <glm/glw.hpp>
//
//void test_opengl_wrapper()
//{
// glVertex(glm::vec3(1.0f));
//}
void fast_inverse()
{
float one = fastInverseSqrt(1.0f);
float two = fastInverseSqrt(2.0f);
float result = 1.0f;
}
//void test_desk()
//{
// typedef glm::detail::desc<glm::vec4>::value_type vec4_type;
// vec4_type Test(1.0f);
//
// glm::detail::desc<glm::vec4>::size_type Size = glm::detail::desc<glm::vec4>::value_size();
//
// int end = 0;
//}
//template <typename genType>
//genType TemplateFuncMin(const genType& Type1, const genType& Type2)
//{
// genType Result;
// for
// (
// glm::detail::desc<glm::vec4>::size_type i = glm::detail::desc<glm::vec4>::size_type(0);
// i < glm::detail::desc<glm::vec4>::value_size;
// ++i
// )
// {
// Result[i] = Type1[i] < Type2[i] ? Type1[i] : Type2[i];
// }
//
// return Result;
//}
//
//void test_genType()
//{
// glm::vec1 Result1 = TemplateFuncMin(glm::vec1(1), glm::vec1(2));
//// float ResultF = TemplateFuncMin(1.f, 2.f);
// vec4 Result4 = TemplateFuncMin(glm::vec4(1), glm::vec4(2));
//
// bool end = true;
//}
namespace test_ac
{
struct C1
{
C1() :
data(76)
{}
int data;
};
struct C2
{
C2(){}
C2(const C1& c1) :
data(c1.data)
{}
int data;
};
C2 operator+ (const C2& a, const C2& b)
{
C2 result;
result.data = a.data + b.data;
return result;
}
}
void test_auto_cast()
{
test_ac::C1 c1;
test_ac::C2 c2 = c1;
test_ac::C2 c3 = c2 + c1;
//
// glm::vec3 Data = glm::vec2(1.f)._yxy();
}
template <typename genType>
genType abs(const genType& v)
{
genType Result;
for(typename genType::size_type i = 0; i < genType::size_value; ++i)
Result[i] = Result[i] < typename genType::value_type(0) ? -Result[i] : Result[i];
return Result;
}
void test_quaternion()
{
glm::vec3 tan(1.0f);
glm::quat q;
tan = glm::cross(q, tan);
}
void test_swizzle()
{
glm::vec2 a(1, 2);
glm::vec4 b = a.swizzle(X, Y, X, Y);
glm::vec4 c(0);
c.swizzle(X, Y, Z, W) = b.swizzle(X, Y, Z, W);
//a.xyz = b.xyz;
bool end = true;
}
void test_angle()
{
//float angle1 = glm::angle(0.1f, 0.2f);
float angle2 = glm::angle(glm::vec2(0.1f), glm::vec2(0.2f));
return;
}
void test_half()
{
hmat2 hmatrix1(half(1.f));
hmat2 hmatrix2(half(2.f));
hmat2 hmatrix3 = hmatrix1 + hmatrix2;
half hscalar = hmatrix3[0].x;
double fscalar = hscalar;
hvec2::size_type Size = hvec2::value_size();
return;
}
template <typename valType, profile proType>
valType func_profile(glm::detail::tvec3<valType> const & x, valType y)
{
return glm::dot(x, glm::detail::tvec3<valType>(y));
}
template <>
float func_profile<float, fast>(glm::vec3 const & x, float y)
{
return glm::dot(x, glm::vec3(y));
}
void test_profile()
{
}
//template <typename valType, int C, int R>
//class TestType
//{
//public:
// TestType(valType const & x);
//};
//
//template <typename valType, int C, int R>
//TestType<valType, C, R>::TestType(valType const & x)
//{}
//
//template <typename valType>
//class TestType<valType, 4, 1>
//{
//public:
// TestType(valType const & x);
//};
//
//template <typename valType>
//TestType<valType, 4, 1>::TestType(valType const & x)
//{}
//
//typedef TestType<float, 4, 1> _vec4;
//
//void test_type()
//{
// _vec4 v(1.0);
//}
void test_fast_inverse()
{
printf("fastInvSqrt(1.0f) : %f\n", fastInverseSqrt(1.0f));
printf("fastInvSqrt(1.0f) : %f\n", inversesqrt(1.0f));
printf("fastInvSqrt(76.0f) : %f\n", fastInverseSqrt(76.f));
printf("fastInvSqrt(76.0f) : %f\n", inversesqrt(76.f));
printf("fastInvSqrt(0.01f) : %f\n", fastInverseSqrt(0.01f));
printf("fastInvSqrt(0.01f) : %f\n", inversesqrt(0.01f));
}
namespace ns_hint
{
struct hint
{};
struct see : public hint
{};
struct see2 : public see
{};
template <typename vecType>
vecType func(vecType const & v, hint)
{
return v * v;
}
template <typename vecType>
vecType func(vecType const & v, see2)
{
return v * v;
}
template <typename valType, typename Hint = hint>
struct vec4
{
vec4()
{
int i = 0;
}
valType data;
};
template <typename valType>
struct vec4<valType, see2>
{
vec4()
{
int i = 0;
}
valType data;
};
//enum hint
//{
// fast,
// nice,
// see,
// see2,
// see3,
// see4
//};
//template <typename vecType, hint Hint = see2>
//vecType func(vecType const & v);
//template <hint Hint = see2>
//struct functor
//{
// template <typename vecType>
// vecType operator() (vecType const & v) const
// {
// return v * v;
// }
//};
}
void test_hint()
{
glm::vec3 v1 = glm::vec3(2.0f);
glm::vec3 v2 = ns_hint::func(v1, ns_hint::see());
// ns_hint::vec4 v3;
// ns_hint::vec4<see2> v4;
//glm::vec3 v2 = ns_hint::functor<ns_hint::see2>()(v1);
//glm::vec3 v2 = hint::func<glm::vec3>(v1);
}
void test_const_call
(
glm::mat4 const & m,
glm::vec4 const & v
)
{
float const & Value = m[0][0];
glm::vec4 const & Vector = m[0];
float const & VecRef = v[0];
float const * const ValuePtr = &m[0][0];
glm::vec4 const * const VectorPtr = &m[0];
float const * VecPtr = &v[0];
}
void test_const()
{
test_const_call(
glm::mat4(1.0),
glm::vec4(1.0));
}
void test_transform()
{
glm::vec2 QMin(-1024,+1024);
//glm::vec2 QMax(+1024,-1024);
glm::vec2 QMax(-1024 + 640, 1024);
std::size_t const ValueSize = 6;
glm::vec3 ValueOut[ValueSize];
glm::vec3 ValueData[ValueSize];
ValueData[0] = glm::vec3(QMin.x, QMin.y, 1);//(0, 0)
ValueData[1] = glm::vec3(QMax.x, QMin.y, 1);//(1, 0)
ValueData[2] = glm::vec3(QMax.x, QMax.y, 1);//(1, 1)
ValueData[3] = glm::vec3(QMin.x, QMax.y, 1);//(0, 1)
ValueData[4] = glm::vec3(QMin.x, QMax.y / 4.f, 1);//(0, 0.25f)
ValueData[5] = glm::vec3(QMin.x / 4.f, QMax.y, 1);//(0.25f, 0.25f)
glm::mat3 Q2Norm(1.0f);
Q2Norm[0] = glm::vec3(
1.0f / (QMax.x - QMin.x),
0.0f,
0.0f);
Q2Norm[1] = glm::vec3(
0.0f,
1.0f / (QMax.y - QMin.y),
0.0f);
Q2Norm[2] = glm::vec3(
- QMin.x / (QMax.x - QMin.x),
- QMin.y / (QMax.y - QMin.y),
1.0f);
glm::vec2 FBMin(0, 0);
glm::vec2 FBMax(640, 480);
glm::mat3 Norm2FB(1.0f);
Norm2FB[0] = glm::vec3(FBMax.x - FBMin.x, 0, 0);
Norm2FB[1] = glm::vec3(0, FBMax.y - FBMin.y, 0);
Norm2FB[2] = glm::vec3(0, 0, 1);
for(std::size_t i = 0; i < ValueSize; ++i)
ValueOut[i] = Norm2FB * Q2Norm * ValueData[i];
bool End = true;
}
//namespace
//{
// template <typename valType>
// valType radialGradient(
// glm::detail::tvec2<valType> const & Center,
// valType const & Radius,
// glm::detail::tvec2<valType> const & Focal,
// glm::detail::tvec2<valType> const & Position)
// {
// glm::detail::tvec2<valType> F = Focal - Center;
// glm::detail::tvec2<valType> D = Position - Focal;
//
// valType Numerator = (D.x * F.x + D.y * F.y) + glm::sqrt((Radius * Radius) * (D.x * D.x + D.y * D.y) - (D.x * F.y - D.y * F.x) * (D.x * F.y - D.y * F.x));
// valType Denominator = (Radius * Radius) - (F.x * F.x + F.y * F.y);
// return Numerator / Denominator;
// }
//}
void test_radial()
{
glm::vec2 Center(0);
float Radius = 1.0f;
glm::vec2 Focal(0);
glm::vec2 PositionA(0);
glm::vec2 PositionB(0, 1);
glm::vec2 PositionC(1, 0);
glm::vec2 PositionD(0.5f, 0.0f);
float GradA = glm::radialGradient(Center, Radius, Focal, PositionA);
float GradB = glm::radialGradient(Center, Radius, Focal, PositionB);
float GradC = glm::radialGradient(Center, Radius, Focal, PositionC);
float GradD = glm::radialGradient(Center, Radius, Focal, PositionD);
bool End = true;
}
void test_quat()
{
glm::quat q1(1.0f, glm::vec3(0));
float Roll = glm::roll(q1);
}
//
//void _mm_add_ps(__m128 in1[4], __m128 in2[4], __m128 out[4])
//{
// {
// out[0] = _mm_add_ps(in1[0], in2[0]);
// out[1] = _mm_add_ps(in1[1], in2[1]);
// out[2] = _mm_add_ps(in1[2], in2[2]);
// out[3] = _mm_add_ps(in1[3], in2[3]);
// }
//}
//
//void _mm_sub_ps(__m128 in1[4], __m128 in2[4], __m128 out[4])
//{
// {
// out[0] = _mm_sub_ps(in1[0], in2[0]);
// out[1] = _mm_sub_ps(in1[1], in2[1]);
// out[2] = _mm_sub_ps(in1[2], in2[2]);
// out[3] = _mm_sub_ps(in1[3], in2[3]);
// }
//}
//
//inline __m128 _mm_mul_ps(__m128 m[4], __m128 v)
//{
// __m128 v0 = _mm_shuffle_ps(v, v, _MM_SHUFFLE(0, 0, 0, 0));
// __m128 v1 = _mm_shuffle_ps(v, v, _MM_SHUFFLE(1, 1, 1, 1));
// __m128 v2 = _mm_shuffle_ps(v, v, _MM_SHUFFLE(2, 2, 2, 2));
// __m128 v3 = _mm_shuffle_ps(v, v, _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 m0 = _mm_mul_ps(m[0], v0);
// __m128 m1 = _mm_mul_ps(m[1], v1);
// __m128 m2 = _mm_mul_ps(m[2], v2);
// __m128 m3 = _mm_mul_ps(m[3], v3);
//
// __m128 a0 = _mm_add_ps(m0, m1);
// __m128 a1 = _mm_add_ps(m2, m3);
// __m128 a2 = _mm_add_ps(a0, a1);
//
// return a2;
//}
//
//inline __m128 _mm_mul_ps(__m128 v, __m128 m[4])
//{
// __m128 i0 = m[0];
// __m128 i1 = m[1];
// __m128 i2 = m[2];
// __m128 i3 = m[3];
//
// __m128 m0 = _mm_mul_ps(v, i0);
// __m128 m1 = _mm_mul_ps(v, i1);
// __m128 m2 = _mm_mul_ps(v, i2);
// __m128 m3 = _mm_mul_ps(v, i3);
//
// __m128 u0 = _mm_unpacklo_ps(m0, m1);
// __m128 u1 = _mm_unpackhi_ps(m0, m1);
// __m128 a0 = _mm_add_ps(u0, u1);
//
// __m128 u2 = _mm_unpacklo_ps(m2, m3);
// __m128 u3 = _mm_unpackhi_ps(m2, m3);
// __m128 a1 = _mm_add_ps(u2, u3);
//
// __m128 f0 = _mm_movelh_ps(a0, a1);
// __m128 f1 = _mm_movehl_ps(a1, a0);
// __m128 f2 = _mm_add_ps(f0, f1);
//
// return f2;
//}
//
//inline void _mm_mul_ps(__m128 in1[4], __m128 in2[4], __m128 out[4])
//{
// glm::uint64 TimeStart = GetCpuCycle();
//
// {
// __m128 e0 = _mm_shuffle_ps(in2[0], in2[0], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 e1 = _mm_shuffle_ps(in2[0], in2[0], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 e2 = _mm_shuffle_ps(in2[0], in2[0], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 e3 = _mm_shuffle_ps(in2[0], in2[0], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 m0 = _mm_mul_ps(in1[0], e0);
// __m128 m1 = _mm_mul_ps(in1[1], e1);
// __m128 m2 = _mm_mul_ps(in1[2], e2);
// __m128 m3 = _mm_mul_ps(in1[3], e3);
//
// __m128 a0 = _mm_add_ps(m0, m1);
// __m128 a1 = _mm_add_ps(m2, m3);
// __m128 a2 = _mm_add_ps(a0, a1);
//
// out[0] = a2;
// }
//
// {
// __m128 e0 = _mm_shuffle_ps(in2[1], in2[1], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 e1 = _mm_shuffle_ps(in2[1], in2[1], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 e2 = _mm_shuffle_ps(in2[1], in2[1], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 e3 = _mm_shuffle_ps(in2[1], in2[1], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 m0 = _mm_mul_ps(in1[0], e0);
// __m128 m1 = _mm_mul_ps(in1[1], e1);
// __m128 m2 = _mm_mul_ps(in1[2], e2);
// __m128 m3 = _mm_mul_ps(in1[3], e3);
//
// __m128 a0 = _mm_add_ps(m0, m1);
// __m128 a1 = _mm_add_ps(m2, m3);
// __m128 a2 = _mm_add_ps(a0, a1);
//
// out[1] = a2;
// }
//
// {
// __m128 e0 = _mm_shuffle_ps(in2[2], in2[2], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 e1 = _mm_shuffle_ps(in2[2], in2[2], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 e2 = _mm_shuffle_ps(in2[2], in2[2], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 e3 = _mm_shuffle_ps(in2[2], in2[2], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 m0 = _mm_mul_ps(in1[0], e0);
// __m128 m1 = _mm_mul_ps(in1[1], e1);
// __m128 m2 = _mm_mul_ps(in1[2], e2);
// __m128 m3 = _mm_mul_ps(in1[3], e3);
//
// __m128 a0 = _mm_add_ps(m0, m1);
// __m128 a1 = _mm_add_ps(m2, m3);
// __m128 a2 = _mm_add_ps(a0, a1);
//
// out[2] = a2;
// }
//
// {
// //(__m128&)_mm_shuffle_epi32(__m128i&)in2[0], _MM_SHUFFLE(3, 3, 3, 3))
// __m128 e0 = _mm_shuffle_ps(in2[3], in2[3], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 e1 = _mm_shuffle_ps(in2[3], in2[3], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 e2 = _mm_shuffle_ps(in2[3], in2[3], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 e3 = _mm_shuffle_ps(in2[3], in2[3], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 m0 = _mm_mul_ps(in1[0], e0);
// __m128 m1 = _mm_mul_ps(in1[1], e1);
// __m128 m2 = _mm_mul_ps(in1[2], e2);
// __m128 m3 = _mm_mul_ps(in1[3], e3);
//
// __m128 a0 = _mm_add_ps(m0, m1);
// __m128 a1 = _mm_add_ps(m2, m3);
// __m128 a2 = _mm_add_ps(a0, a1);
//
// out[3] = a2;
// }
//
// glm::uint64 TimeEnd = GetCpuCycle();
//
// printf("Ticks mul: %d\n", TimeEnd - TimeStart);
//}
//
//inline void _mm_transpose_ps(__m128 const in[4], __m128 out[4])
//{
// __m128 tmp0 = _mm_shuffle_ps(in[0], in[1], 0x44);
// __m128 tmp2 = _mm_shuffle_ps(in[0], in[1], 0xEE);
// __m128 tmp1 = _mm_shuffle_ps(in[2], in[3], 0x44);
// __m128 tmp3 = _mm_shuffle_ps(in[2], in[3], 0xEE);
//
// out[0] = _mm_shuffle_ps(tmp0, tmp1, 0x88);
// out[1] = _mm_shuffle_ps(tmp0, tmp1, 0xDD);
// out[2] = _mm_shuffle_ps(tmp2, tmp3, 0x88);
// out[3] = _mm_shuffle_ps(tmp2, tmp3, 0xDD);
//}
//void _mm_inverse_ps(__m128 const in[4], __m128 out[4])
//{
// // Swp00 = _mm_shuffle_ps(in[1], in[2], _MM_SHUFFLE(2, 2, 2, 2));
// // SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// // SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// // SubFactor06 = m[1][2] * m[3][3] - m[3][2] * m[1][3];
// // SubFactor13 = m[1][2] * m[2][3] - m[2][2] * m[1][3];
// // + (m[1][1] * SubFactor00 - m[1][2] * SubFactor01 + m[1][3] * SubFactor02),
// // - (m[0][1] * SubFactor00 - m[0][2] * SubFactor01 + m[0][3] * SubFactor02),
// // + (m[0][1] * SubFactor06 - m[0][2] * SubFactor07 + m[0][3] * SubFactor08),
// // - (m[0][1] * SubFactor13 - m[0][2] * SubFactor14 + m[0][3] * SubFactor15),
//
// __m128 Sfc00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 Sfc0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(3, 2, 3, 2));
// __m128 Sfc01 = _mm_shuffle_ps(Sfc0a, Sfc0a, _MM_SHUFFLE(2, 3, 1, 1));
// __m128 Sfc02 = _mm_shuffle_ps(Sfc0a, Sfc0a, _MM_SHUFFLE(3, 2, 0, 0));
// __m128 Sfc03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 SfcM0 = _mm_mul_ps(Sfc00, Sfc01);
// __m128 SfcM1 = _mm_mul_ps(Sfc02, Sfc03);
// __m128 SfcM2 = _mm_sub_ps(SfcM0, SfcM1);
// // SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// // SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// // SubFactor06 = m[1][2] * m[3][3] - m[3][2] * m[1][3];
// // SubFactor13 = m[1][2] * m[2][3] - m[2][2] * m[1][3];
// // + (m[1][1] * SubFactor00 - m[1][2] * SubFactor01 + m[1][3] * SubFactor02),
// // - (m[0][1] * SubFactor00 - m[0][2] * SubFactor01 + m[0][3] * SubFactor02),
// // + (m[0][1] * SubFactor06 - m[0][2] * SubFactor07 + m[0][3] * SubFactor08),
// // - (m[0][1] * SubFactor13 - m[0][2] * SubFactor14 + m[0][3] * SubFactor15),
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[2], _MM_SHUFFLE(3, 0, 1, 2));
// __m128 Swp01 = _mm_shuffle_ps(in[3], in[3], _MM_SHUFFLE(3, 3, 3, 3));
// __m128 Swp02 = _mm_shuffle_ps(in[3], in[3], _MM_SHUFFLE(3, 0, 1, 2));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[2], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 Swp04 = _mm_shuffle_ps(in[2], in[2], _MM_SHUFFLE(3, 0, 0, 1));
// __m128 Swp05 = _mm_shuffle_ps(in[3], in[3], _MM_SHUFFLE(3, 1, 2, 2));
// __m128 Swp06 = _mm_shuffle_ps(in[3], in[3], _MM_SHUFFLE(3, 0, 0, 1));
// __m128 Swp07 = _mm_shuffle_ps(in[2], in[2], _MM_SHUFFLE(3, 1, 2, 2));
//
// __m128 Swp08 = _mm_shuffle_ps(in[1], in[1], _MM_SHUFFLE(3, 0, 1, 2));
// __m128 Swp09 = _mm_shuffle_ps(in[1], in[1], _MM_SHUFFLE(3, 3, 3, 3));
// __m128 Swp10 = _mm_shuffle_ps(in[1], in[1], _MM_SHUFFLE(3, 0, 0, 1));
// __m128 Swp11 = _mm_shuffle_ps(in[1], in[1], _MM_SHUFFLE(3, 1, 2, 2));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// __m128 Fac00 = _mm_sub_ps(Mul00, Mul01);
//
// //valType SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// //valType SubFactor01 = m[2][1] * m[3][3] - m[3][1] * m[2][3];
// //valType SubFactor03 = m[2][0] * m[3][3] - m[3][0] * m[2][3];
//
// __m128 Mul02 = _mm_mul_ps(Swp04, Swp05);
// __m128 Mul03 = _mm_mul_ps(Swp06, Swp07);
// __m128 Fac01 = _mm_sub_ps(Mul02, Mul03);
//
// //valType SubFactor02 = m[2][1] * m[3][2] - m[3][1] * m[2][2];
// //valType SubFactor04 = m[2][0] * m[3][2] - m[3][0] * m[2][2];
// //valType SubFactor05 = m[2][0] * m[3][1] - m[3][0] * m[2][1];
//
// __m128 Mul04 = _mm_mul_ps(Swp08, Swp01);
// __m128 Mul05 = _mm_mul_ps(Swp02, Swp09);
// __m128 Fac02 = _mm_sub_ps(Mul04, Mul05);
//
// //valType SubFactor06 = m[1][2] * m[3][3] - m[3][2] * m[1][3];
// //valType SubFactor07 = m[1][1] * m[3][3] - m[3][1] * m[1][3];
// //valType SubFactor09 = m[1][0] * m[3][3] - m[3][0] * m[1][3];
//
// __m128 Mul06 = _mm_mul_ps(Swp10, Swp05);
// __m128 Mul07 = _mm_mul_ps(Swp06, Swp11);
// __m128 Fac03 = _mm_sub_ps(Mul06, Mul07);
//
// //valType SubFactor08 = m[1][1] * m[3][2] - m[3][1] * m[1][2];
// //valType SubFactor10 = m[1][0] * m[3][2] - m[3][0] * m[1][2];
// //valType SubFactor12 = m[1][0] * m[3][1] - m[3][0] * m[1][1];
//
// __m128 Mul08 = _mm_mul_ps(Swp08, Swp03);
// __m128 Mul09 = _mm_mul_ps(Swp00, Swp09);
// __m128 Fac04 = _mm_sub_ps(Mul08, Mul09);
//
// //valType SubFactor13 = m[1][2] * m[2][3] - m[2][2] * m[1][3];
// //valType SubFactor14 = m[1][1] * m[2][3] - m[2][1] * m[1][3];
// //valType SubFactor16 = m[1][0] * m[2][3] - m[2][0] * m[1][3];
//
// __m128 Mul10 = _mm_mul_ps(Swp10, Swp07);
// __m128 Mul11 = _mm_mul_ps(Swp04, Swp11);
// __m128 Fac05 = _mm_sub_ps(Mul10, Mul11);
//
// //valType SubFactor15 = m[1][1] * m[2][2] - m[2][1] * m[1][2];
// //valType SubFactor17 = m[1][0] * m[2][2] - m[2][0] * m[1][2];
// //valType SubFactor18 = m[1][0] * m[2][1] - m[2][0] * m[1][1];
//
// bool end = true;
//}
//template <typename valType>
//inline detail::tmat4x4<valType> inverse
//(
// detail::tmat4x4<valType> const & m
//)
//{
//inline __m128 _mm_dot_ps(__m128 v1, __m128 v2)
//{
// __m128 mul0 = _mm_mul_ps(v1, v2);
// __m128 swp0 = _mm_shuffle_ps(mul0, mul0, _MM_SHUFFLE(2, 3, 0, 1));
// __m128 add0 = _mm_add_ps(mul0, swp0);
// __m128 swp1 = _mm_shuffle_ps(add0, add0, _MM_SHUFFLE(0, 1, 2, 3));
// __m128 add1 = _mm_add_ps(add0, swp1);
// return add1;
//}
//
//inline void _mm_inverse_ps(__m128 const in[4], __m128 out[4])
//{
// glm::uint64 TimeStart = GetCpuCycle();
//
// __m128 Fac0;
// {
// // valType SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// // valType SubFactor00 = m[2][2] * m[3][3] - m[3][2] * m[2][3];
// // valType SubFactor06 = m[1][2] * m[3][3] - m[3][2] * m[1][3];
// // valType SubFactor13 = m[1][2] * m[2][3] - m[2][2] * m[1][3];
//
// __m128 Swp0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(3, 3, 3, 3));
// __m128 Swp0b = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(2, 2, 2, 2));
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 Swp01 = _mm_shuffle_ps(Swp0a, Swp0a, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp02 = _mm_shuffle_ps(Swp0b, Swp0b, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// Fac0 = _mm_sub_ps(Mul00, Mul01);
//
// bool stop = true;
// }
//
// __m128 Fac1;
// {
// // valType SubFactor01 = m[2][1] * m[3][3] - m[3][1] * m[2][3];
// // valType SubFactor01 = m[2][1] * m[3][3] - m[3][1] * m[2][3];
// // valType SubFactor07 = m[1][1] * m[3][3] - m[3][1] * m[1][3];
// // valType SubFactor14 = m[1][1] * m[2][3] - m[2][1] * m[1][3];
//
// __m128 Swp0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(3, 3, 3, 3));
// __m128 Swp0b = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(1, 1, 1, 1));
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 Swp01 = _mm_shuffle_ps(Swp0a, Swp0a, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp02 = _mm_shuffle_ps(Swp0b, Swp0b, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// Fac1 = _mm_sub_ps(Mul00, Mul01);
//
// bool stop = true;
// }
//
//
// __m128 Fac2;
// {
// // valType SubFactor02 = m[2][1] * m[3][2] - m[3][1] * m[2][2];
// // valType SubFactor02 = m[2][1] * m[3][2] - m[3][1] * m[2][2];
// // valType SubFactor08 = m[1][1] * m[3][2] - m[3][1] * m[1][2];
// // valType SubFactor15 = m[1][1] * m[2][2] - m[2][1] * m[1][2];
//
// __m128 Swp0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 Swp0b = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(1, 1, 1, 1));
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 Swp01 = _mm_shuffle_ps(Swp0a, Swp0a, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp02 = _mm_shuffle_ps(Swp0b, Swp0b, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(2, 2, 2, 2));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// Fac2 = _mm_sub_ps(Mul00, Mul01);
//
// bool stop = true;
// }
//
// __m128 Fac3;
// {
// // valType SubFactor03 = m[2][0] * m[3][3] - m[3][0] * m[2][3];
// // valType SubFactor03 = m[2][0] * m[3][3] - m[3][0] * m[2][3];
// // valType SubFactor09 = m[1][0] * m[3][3] - m[3][0] * m[1][3];
// // valType SubFactor16 = m[1][0] * m[2][3] - m[2][0] * m[1][3];
//
// __m128 Swp0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(3, 3, 3, 3));
// __m128 Swp0b = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(0, 0, 0, 0));
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 Swp01 = _mm_shuffle_ps(Swp0a, Swp0a, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp02 = _mm_shuffle_ps(Swp0b, Swp0b, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(3, 3, 3, 3));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// Fac3 = _mm_sub_ps(Mul00, Mul01);
//
// bool stop = true;
// }
//
// __m128 Fac4;
// {
// // valType SubFactor04 = m[2][0] * m[3][2] - m[3][0] * m[2][2];
// // valType SubFactor04 = m[2][0] * m[3][2] - m[3][0] * m[2][2];
// // valType SubFactor10 = m[1][0] * m[3][2] - m[3][0] * m[1][2];
// // valType SubFactor17 = m[1][0] * m[2][2] - m[2][0] * m[1][2];
//
// __m128 Swp0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 Swp0b = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(0, 0, 0, 0));
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 Swp01 = _mm_shuffle_ps(Swp0a, Swp0a, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp02 = _mm_shuffle_ps(Swp0b, Swp0b, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(2, 2, 2, 2));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// Fac4 = _mm_sub_ps(Mul00, Mul01);
//
// bool stop = true;
// }
//
// __m128 Fac5;
// {
// // valType SubFactor05 = m[2][0] * m[3][1] - m[3][0] * m[2][1];
// // valType SubFactor05 = m[2][0] * m[3][1] - m[3][0] * m[2][1];
// // valType SubFactor12 = m[1][0] * m[3][1] - m[3][0] * m[1][1];
// // valType SubFactor18 = m[1][0] * m[2][1] - m[2][0] * m[1][1];
//
// __m128 Swp0a = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 Swp0b = _mm_shuffle_ps(in[3], in[2], _MM_SHUFFLE(0, 0, 0, 0));
//
// __m128 Swp00 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 Swp01 = _mm_shuffle_ps(Swp0a, Swp0a, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp02 = _mm_shuffle_ps(Swp0b, Swp0b, _MM_SHUFFLE(2, 0, 0, 0));
// __m128 Swp03 = _mm_shuffle_ps(in[2], in[1], _MM_SHUFFLE(1, 1, 1, 1));
//
// __m128 Mul00 = _mm_mul_ps(Swp00, Swp01);
// __m128 Mul01 = _mm_mul_ps(Swp02, Swp03);
// Fac5 = _mm_sub_ps(Mul00, Mul01);
//
// bool stop = true;
// }
//
// __m128 SignA = _mm_set_ps( 1.0f,-1.0f, 1.0f,-1.0f);
// __m128 SignB = _mm_set_ps(-1.0f, 1.0f,-1.0f, 1.0f);
//
// // m[1][0]
// // m[0][0]
// // m[0][0]
// // m[0][0]
// __m128 Temp0 = _mm_shuffle_ps(in[1], in[0], _MM_SHUFFLE(0, 0, 0, 0));
// __m128 Vec0 = _mm_shuffle_ps(Temp0, Temp0, _MM_SHUFFLE(2, 2, 2, 0));
//
// // m[1][1]
// // m[0][1]
// // m[0][1]
// // m[0][1]
// __m128 Temp1 = _mm_shuffle_ps(in[1], in[0], _MM_SHUFFLE(1, 1, 1, 1));
// __m128 Vec1 = _mm_shuffle_ps(Temp1, Temp1, _MM_SHUFFLE(2, 2, 2, 0));
//
// // m[1][2]
// // m[0][2]
// // m[0][2]
// // m[0][2]
// __m128 Temp2 = _mm_shuffle_ps(in[1], in[0], _MM_SHUFFLE(2, 2, 2, 2));
// __m128 Vec2 = _mm_shuffle_ps(Temp2, Temp2, _MM_SHUFFLE(2, 2, 2, 0));
//
// // m[1][3]
// // m[0][3]
// // m[0][3]
// // m[0][3]
// __m128 Temp3 = _mm_shuffle_ps(in[1], in[0], _MM_SHUFFLE(3, 3, 3, 3));
// __m128 Vec3 = _mm_shuffle_ps(Temp3, Temp3, _MM_SHUFFLE(2, 2, 2, 0));
//
// // col0
// // + (Vec1[0] * Fac0[0] - Vec2[0] * Fac1[0] + Vec3[0] * Fac2[0]),
// // - (Vec1[1] * Fac0[1] - Vec2[1] * Fac1[1] + Vec3[1] * Fac2[1]),
// // + (Vec1[2] * Fac0[2] - Vec2[2] * Fac1[2] + Vec3[2] * Fac2[2]),
// // - (Vec1[3] * Fac0[3] - Vec2[3] * Fac1[3] + Vec3[3] * Fac2[3]),
// __m128 Mul00 = _mm_mul_ps(Vec1, Fac0);
// __m128 Mul01 = _mm_mul_ps(Vec2, Fac1);
// __m128 Mul02 = _mm_mul_ps(Vec3, Fac2);
// __m128 Sub00 = _mm_sub_ps(Mul00, Mul01);
// __m128 Add00 = _mm_add_ps(Sub00, Mul02);
// __m128 Inv0 = _mm_mul_ps(SignB, Add00);
//
// // col1
// // - (Vec0[0] * Fac0[0] - Vec2[0] * Fac3[0] + Vec3[0] * Fac4[0]),
// // + (Vec0[0] * Fac0[1] - Vec2[1] * Fac3[1] + Vec3[1] * Fac4[1]),
// // - (Vec0[0] * Fac0[2] - Vec2[2] * Fac3[2] + Vec3[2] * Fac4[2]),
// // + (Vec0[0] * Fac0[3] - Vec2[3] * Fac3[3] + Vec3[3] * Fac4[3]),
// __m128 Mul03 = _mm_mul_ps(Vec0, Fac0);
// __m128 Mul04 = _mm_mul_ps(Vec2, Fac3);
// __m128 Mul05 = _mm_mul_ps(Vec3, Fac4);
// __m128 Sub01 = _mm_sub_ps(Mul03, Mul04);
// __m128 Add01 = _mm_add_ps(Sub01, Mul05);
// __m128 Inv1 = _mm_mul_ps(SignA, Add01);
//
// // col2
// // + (Vec0[0] * Fac1[0] - Vec1[0] * Fac3[0] + Vec3[0] * Fac5[0]),
// // - (Vec0[0] * Fac1[1] - Vec1[1] * Fac3[1] + Vec3[1] * Fac5[1]),
// // + (Vec0[0] * Fac1[2] - Vec1[2] * Fac3[2] + Vec3[2] * Fac5[2]),
// // - (Vec0[0] * Fac1[3] - Vec1[3] * Fac3[3] + Vec3[3] * Fac5[3]),
// __m128 Mul06 = _mm_mul_ps(Vec0, Fac1);
// __m128 Mul07 = _mm_mul_ps(Vec1, Fac3);
// __m128 Mul08 = _mm_mul_ps(Vec3, Fac5);
// __m128 Sub02 = _mm_sub_ps(Mul06, Mul07);
// __m128 Add02 = _mm_add_ps(Sub02, Mul08);
// __m128 Inv2 = _mm_mul_ps(SignB, Add02);
//
// // col3
// // - (Vec1[0] * Fac2[0] - Vec1[0] * Fac4[0] + Vec2[0] * Fac5[0]),
// // + (Vec1[0] * Fac2[1] - Vec1[1] * Fac4[1] + Vec2[1] * Fac5[1]),
// // - (Vec1[0] * Fac2[2] - Vec1[2] * Fac4[2] + Vec2[2] * Fac5[2]),
// // + (Vec1[0] * Fac2[3] - Vec1[3] * Fac4[3] + Vec2[3] * Fac5[3]));
// __m128 Mul09 = _mm_mul_ps(Vec0, Fac2);
// __m128 Mul10 = _mm_mul_ps(Vec1, Fac4);
// __m128 Mul11 = _mm_mul_ps(Vec2, Fac5);
// __m128 Sub03 = _mm_sub_ps(Mul09, Mul10);
// __m128 Add03 = _mm_add_ps(Sub03, Mul11);
// __m128 Inv3 = _mm_mul_ps(SignA, Add03);
//
// __m128 Row0 = _mm_shuffle_ps(Inv0, Inv1, _MM_SHUFFLE(0, 0, 0, 0));
// __m128 Row1 = _mm_shuffle_ps(Inv2, Inv3, _MM_SHUFFLE(0, 0, 0, 0));
// __m128 Row2 = _mm_shuffle_ps(Row0, Row1, _MM_SHUFFLE(2, 0, 2, 0));
//
// // valType Determinant = m[0][0] * Inverse[0][0]
// // + m[0][1] * Inverse[1][0]
// // + m[0][2] * Inverse[2][0]
// // + m[0][3] * Inverse[3][0];
// __m128 Det0 = _mm_dot_ps(in[0], Row2);
//
// // Inverse /= Determinant;
// out[0] = _mm_div_ps(Inv0, Det0);
// out[1] = _mm_div_ps(Inv1, Det0);
// out[2] = _mm_div_ps(Inv2, Det0);
// out[3] = _mm_div_ps(Inv3, Det0);
//
// glm::uint64 TimeEnd = GetCpuCycle();
//
// printf("Ticks inv: %d\n", TimeEnd - TimeStart);
//
// bool stop = true;
//}
//#include <intrin.h>
void test_mat4_mul()
{
/*
{
__m128 v1 = _mm_set_ps(3.0f, 2.0f, 1.0f, 0.0f);
__m128 m0[4];
m0[0] = _mm_set_ps(3.0f, 2.0f, 1.0f, 0.0f);
m0[1] = _mm_set_ps(4.0f, 5.0f, 6.0f, 7.0f);
m0[2] = _mm_set_ps(0.3f, 0.2f, 0.1f, 0.0f);
m0[3] = _mm_set_ps(0.4f, 0.5f, 0.6f, 0.7f);
__m128 v2 = _mm_mul_ps(v1, m0);
bool stop = true;
}
{
glm::vec4 v1(0.0f, 1.0f, 2.0f, 3.0f);
glm::mat4 m0;
m0[0] = glm::vec4(0.0f, 1.0f, 2.0f, 3.0f);
m0[1] = glm::vec4(7.0f, 6.0f, 5.0f, 4.0f);
m0[2] = glm::vec4(0.0f, 0.1f, 0.2f, 0.3f);
m0[3] = glm::vec4(0.7f, 0.6f, 0.5f, 0.4f);
glm::vec4 v2 = v1 * m0;
bool stop = true;
}
*/
{
__m128 a = _mm_setr_ps(0.0f, 1.0f, 2.0f, 3.0f);
__m128 b = _mm_shuffle_ps(a, a, _MM_SHUFFLE(3, 2, 1, 0));
bool stop = true;
}
{
__m128 v1 = _mm_setr_ps(0.3f, 0.2f, 0.1f, 1.0f);
__m128 m0[4];
m0[0] = _mm_setr_ps(2.0f, 0.2f, 0.1f,-1.4f);
m0[1] = _mm_setr_ps(0.5f, 2.0f, 0.3f,-1.2f);
m0[2] = _mm_setr_ps(0.6f, 0.4f, 2.0f,-1.1f);
m0[3] = _mm_setr_ps(1.4f, 1.2f, 1.1f, 1.0f);
__m128 v2 = _mm_mul_ps(v1, m0);
bool stop = true;
}
{
glm::vec4 v1(0.3f, 0.2f, 0.1f, 1.0f);
glm::mat4 m0;
m0[0] = glm::vec4(2.0f, 0.2f, 0.1f,-1.4f);
m0[1] = glm::vec4(0.5f, 2.0f, 0.3f,-1.2f);
m0[2] = glm::vec4(0.6f, 0.4f, 2.0f,-1.1f);
m0[3] = glm::vec4(1.4f, 1.2f, 1.1f, 1.0f);
glm::vec4 v2 = v1 * m0;
bool stop = true;
}
{
glm::vec4 v1(1.0f, 0.5f,-0.5f,-1.0f);
glm::mat4 m0;
m0[0] = glm::vec4(2.0f,-1.0f,-1.0f, 4.0f);
m0[1] = glm::vec4(2.0f, 1.0f, 4.0f, 1.0f);
m0[2] = glm::vec4(2.0f, 4.0f, 1.0f, 1.0f);
m0[3] = glm::vec4(4.0f, 1.0f, 1.0f, 1.0f);
m0 = glm::transpose(m0);
glm::vec4 v2 = m0 * v1;
bool stop = true;
}
{
glm::mat4 MatA;
MatA[0] = glm::vec4(0.2f, 0.1f, 0.3f, 0.4f);
MatA[1] = glm::vec4(1.0f, 0.3f, 0.2f, 0.3f);
MatA[2] = glm::vec4(3.0f, 2.0f, 0.4f, 0.2f);
MatA[3] = glm::vec4(4.0f, 3.0f, 2.0f, 1.0f);
glm::mat4 InvA = glm::inverse(MatA);
glm::mat4 IndA = MatA * InvA;
// glm::mat4 InvB = glm::inverseOgre(MatA);
// glm::mat4 IndB = MatA * InvB;
// glm::mat4 InvD = glm::inverseSIMD(MatA);
// glm::mat4 IndD = MatA * InvD;
// glm::mat4 InvE = glm::inverseDev(MatA);
// glm::mat4 IndE = MatA * InvE;
__m128 MatC[4];
MatC[0] = _mm_setr_ps(0.2f, 0.1f, 0.3f, 0.4f);
MatC[1] = _mm_setr_ps(1.0f, 0.3f, 0.2f, 0.3f);
MatC[2] = _mm_setr_ps(3.0f, 2.0f, 0.4f, 0.2f);
MatC[3] = _mm_setr_ps(4.0f, 3.0f, 2.0f, 1.0f);
__m128 InvC[4];
_mm_inverse_ps(MatC, InvC);
__m128 IndC[4];
_mm_mul_ps(MatC, InvC, IndC);
__m128 Mul2[4];
_mm_mul_ps(MatC, MatC, Mul2);
bool stop = true;
}
{
glm::dmat4 Mat;
Mat[0] = glm::dvec4(0.0f, 1.0f, 2.0f, 3.0f);
Mat[1] = glm::dvec4(0.1f, 1.1f, 2.1f, 3.1f);
Mat[2] = glm::dvec4(0.2f, 1.2f, 2.2f, 3.2f);
Mat[3] = glm::dvec4(0.3f, 1.3f, 2.3f, 3.3f);
glm::dmat4 Inv = glm::inverse(Mat);
glm::dmat4 Ind = Mat * Inv;
glm::dmat4 MatB;
MatB[0] = glm::dvec4(0.0f, 1.0f, 2.0f, 3.0f);
MatB[1] = glm::dvec4(0.1f, 1.1f, 2.1f, 3.1f);
MatB[2] = glm::dvec4(0.2f, 1.2f, 2.2f, 3.2f);
MatB[3] = glm::dvec4(0.3f, 1.3f, 2.3f, 3.3f);
// glm::dmat4 InvB = glm::inverseOgre(MatB);
// glm::dmat4 IndB = MatB * InvB;
bool stop = true;
}
{
glm::mat3 Mat;
Mat[0] = glm::vec3(0.0f, 1.0f, 2.0f);
Mat[1] = glm::vec3(0.1f, 1.1f, 2.1f);
Mat[2] = glm::vec3(0.2f, 1.2f, 2.2f);
glm::mat3 Inv = glm::inverse(Mat);
glm::mat3 Ind = Mat * Inv;
bool stop = true;
}
bool stop = true;
}
void test_vec4_mul()
{
glm::vec4 v1(1.0f, 2.0f, 3.0f, 4.0f);
glm::mat4 m1;
m1[0] = glm::vec4(1.0f, 2.0f, 3.0f, 4.0f) * 0.1f;
m1[1] = glm::vec4(1.0f, 2.0f, 3.0f, 4.0f) * 0.2f;
m1[2] = glm::vec4(1.0f, 2.0f, 3.0f, 4.0f) * 0.3f;
m1[3] = glm::vec4(1.0f, 2.0f, 3.0f, 4.0f) * 0.4f;
glm::vec4 vA = m1 * v1;
glm::vec4 vC = v1 * m1;
__m128 v2 = _mm_setr_ps(1.0f, 2.0f, 3.0f, 4.0f);
__m128 m2[4];
m2[0] = _mm_mul_ps(_mm_setr_ps(1.0f, 2.0f, 3.0f, 4.0f), _mm_set_ps1(0.1f));
m2[1] = _mm_mul_ps(_mm_setr_ps(1.0f, 2.0f, 3.0f, 4.0f), _mm_set_ps1(0.2f));
m2[2] = _mm_mul_ps(_mm_setr_ps(1.0f, 2.0f, 3.0f, 4.0f), _mm_set_ps1(0.3f));
m2[3] = _mm_mul_ps(_mm_setr_ps(1.0f, 2.0f, 3.0f, 4.0f), _mm_set_ps1(0.4f));
__m128 vB = _mm_mul_ps(m2, v2);
__m128 vD = _mm_mul_ps(v2, m2);
bool stop = true;
}
void test_mat4_tick()
{
__m128 MatC[4];
MatC[0] = _mm_setr_ps(0.2f, 0.1f, 0.3f, 0.4f);
MatC[1] = _mm_setr_ps(1.0f, 0.3f, 0.2f, 0.3f);
MatC[2] = _mm_setr_ps(3.0f, 2.0f, 0.4f, 0.2f);
MatC[3] = _mm_setr_ps(4.0f, 3.0f, 2.0f, 1.0f);
int CPUInfo[4];
int InfoType;
for(std::size_t i = 0; i < 10; ++i)
{
__m128 InvC[4];
__m128 IndC[4];
{
// __cpuid(CPUInfo, InfoType);
// __rdtsc();
// __cpuid(CPUInfo, InfoType);
// __rdtsc();
// __cpuid(CPUInfo, InfoType);
//glm::uint64 ClockStart = GetCpuCycle();
_mm_inverse_ps(MatC, InvC);
//glm::uint64 ClockEnd = GetCpuCycle();
//printf("inv: %d\n", ClockEnd - ClockStart);
}
{
// __cpuid(CPUInfo, InfoType);
// __rdtsc();
// __cpuid(CPUInfo, InfoType);
// __rdtsc();
// __cpuid(CPUInfo, InfoType);
//glm::uint64 ClockStart = GetCpuCycle();
_mm_mul_ps(MatC, InvC, IndC);
//glm::uint64 ClockEnd = GetCpuCycle();
//printf("mul: %d\n", ClockEnd - ClockStart);
}
}
}
int firstBit(int Binary)
{
for(std::size_t i = 0; i < 32; ++i)
if(Binary & (1 << i))
return i;
assert(0);
return 0;
}
void test_exp_golomb()
{
//0 => 1 => 1
//1 => 10 => 010
//2 => 11 => 011
//3 => 100 => 00100
//4 => 101 => 00101
//5 => 110 => 00110
//6 => 111 => 00111
//7 => 1000 => 0001000
//8 => 1001 => 0001001
// - Take the number in binary except for the last k digits
// and add 1 to it (arithmetically). Write this down.
// - Count the bits written, subtract one,
// - Write that number of starting zero bits preceding the previous bit string.
// - Write the last k bits in binary.
std::size_t Bit00 = glm::highestBit(0);
std::size_t Bit01 = glm::highestBit(1);
std::size_t Bit02 = glm::highestBit(2);
std::size_t Bit04 = glm::highestBit(4);
std::size_t Bit08 = glm::highestBit(8);
std::size_t Bit16 = glm::highestBit(16);
std::size_t Bit32 = glm::highestBit(32);
std::vector<glm::uint32> Size(256);
std::vector<glm::uint32> Data(256);
std::vector<glm::uint32> Conv(256);
for(std::size_t i = 0; i < 256; ++i)
{
glm::uint32 Binary = i + 1;
glm::uint32 HighestBit = glm::highestBit(Binary);
glm::uint32 CodeSize = (HighestBit << 1) + 1;
glm::uint32 Swift = 32 - CodeSize;
glm::uint32 Temp = glm::bitRevert(Binary << Swift);
//glm::uint32 Temp = Binary << Swift;
Data[i] = Temp;
Size[i] = HighestBit * 2 + 1;
printf("Binary(%d, %d): ", Swift, CodeSize);
for(std::size_t k = 0; k < 32; ++k)
printf("%d", glm::uint32((Binary & (1 << k)) != 0));
printf(" (%d)\n", Binary);
printf("Temp(%d, %d) : ", Swift, CodeSize);
for(std::size_t k = 0; k < 32; ++k)
printf("%d", glm::uint32((Temp & (1 << k)) != 0));
printf(" (%d)\n", Temp);
printf("Value(%d): ", i);
for(std::size_t k = 0; k < 8; ++k)
printf("%d", glm::uint32((i & (1 << k)) != 0));
printf("; ");
printf("Code: ");
for(std::size_t k = 0; k < Size[i]; ++k)
printf("%d", glm::uint32((Data[i] & (1 << k)) != 0));
printf("\n");
{
glm::uint32 Temp = Data[i];
glm::uint32 CodeSize2 = (firstBit(Temp) << 1) + 1;
glm::uint32 Swift2 = 32 - CodeSize2;
glm::uint32 Binary = glm::bitRevert(Temp) >> Swift2;
Conv[i] = Binary - 1;
}
printf("Conv (%d, %d): ", Swift, CodeSize);
for(std::size_t k = 0; k < 32; ++k)
printf("%d", glm::uint32((Conv[i] & (1 << k)) != 0));
printf(" (%d)\n\n", Conv[i]);
bool stop = true;
}
bool stop = true;
}
/*
int main(int argc, char* argv[])
{
test_mat4_mul();
test_exp_golomb();
//test_mat4_tick();
test_quat();
test_simd();
test_transform();
test_const();
test_radial();
test_vec4_mul();
glm::uint LowestBit = glm::lowestBit(8);
glm::test::main_core_func_common();
glm::test::main_core_func_exponential();
glm::test::main_core_func_geometric();
glm::test::main_core_func_matrix();
glm::test::main_core_func_noise();
glm::test::main_core_func_trigonometric();
glm::test::main_core_func_vector_relational();
glm::test::main_gtx_intesect();
{
glm::vec3 Normal(1, 0, 0);
glm::vec3 x = glm::rotate<glm::vec3::value_type>(glm::vec3(1,0,0),180.f,Normal);
glm::vec3 y = glm::rotate<glm::vec3::value_type>(glm::vec3(1,1,0),180.f,Normal);
bool Stop = true;
}
glm::mat4 m1 = glm::inverseTranspose(
glm::gtc::matrix_transform::translate(
glm::gtc::matrix_transform::rotate(
glm::mat4(1.0f),
90.f,
glm::normalize(glm::vec3(1.0f, 0.5f, 0.2f))),
glm::vec3(1.f, 2.f, 3.f)));
glm::mat4 m2 = glm::transpose(
glm::inverse(
glm::gtc::matrix_transform::translate(
glm::gtc::matrix_transform::rotate(
glm::mat4(1.0f),
90.f,
glm::normalize(glm::vec3(1.0f, 0.5f, 0.2f))),
glm::vec3(1.f, 2.f, 3.f))));
test_hint();
test_fast_inverse();
//test_type();
test_profile();
// glm::greaterThan();
test_angle();
test_half();
test_swizzle();
test::main_vec2();
test_quaternion();
test_auto_cast();
//detail::test_half_type();
glm::vec2 Result = glm::perp(glm::vec2(1.0, 0.0), glm::vec2(0.0, 1.0));
// test_genType();
// test_desk();
//radians(1);
glm::mat4 LookAt = glm::lookAt(glm::vec3(1), glm::vec3(1), glm::vec3(1));
fast_inverse();
test_string_cast();
test_isPowerOfTwo();
{
float fast0 = glm::fastLength(glm::vec3(1.0f));
float fast1 = 0.0f;
}
vec4 v76 = 1.f * vec4(1.0f);
test_matrix();
//test_random();
//test_sse_vec4();
//test_sse_mat4();
{
float f1 = glm::mix(100.f, 1000.f, 0.5f);
vec3 f2 = glm::mix(vec3(100.f), vec3(1000.f), 0.5f);
ivec3 f3 = glm::mix(ivec3(100), ivec3(1000), 0.5f);
ivec3 f4 = glm::mix(ivec3(100), ivec3(1000), vec3(0.5f));
}
{
mat4 Projection = glm::frustum(-1.0f, 1.0f, -1.0f, 1.0f, 0.1f, 1.0f);
//glm_traits<glm::vec3>::value_type vec(1.0f);
}
{
glm::vec2 v1(1.0f);
glm::vec2 v2(2.0f);
glm::vec2 v3(3.0f);
// v1.xy += v2 + v3.xy;
}
{
bool b = true;
glm::vec4 v4(b);
}
{
glm::quat q1;
q1 = glm::inverse(q1);
}
//test_cast();
//test_half_full();
//test_sse();
//__hvec2GTX Pouet;
//pouet Pouet(1, 2, 3);
glm::dmat4 dm = glm::dmat4(1.0);
glm::mat4 fm1 = glm::mat4(dm);
glm::mat4 fm2(dm);
//glm::hmat4 hm = glm::hmat4(1.0);
//glm::mat4 fm3(hm);
//glm::dmat4 dm2(hm);
{
glm::quat q1;
glm::vec4 v1;
glm::vec4 r1;
r1 = q1 * v1;
r1++;
//q1 = glm::absGTX(q1);
}
{
glm::vec3 v1(1.0f);
++v1;
v1++;
}
{
glm::vec4 v1(1.0f);
--v1;
v1--;
}
{
glm::vec4 v1(1.0f);
++v1;
v1++;
}
{
ivec3 testVec = ivec3(3,35,4);
const ivec3 testVec2 = ivec3(13,15,14);
//testVec = testVec2.zyx;
//testVec = testVec2.xyy;
//testVec = testVec2.rrr;
//ivec4 textVec4 = testVec2.zzxx;
//ivec2 textVec2 = testVec2.gr;
//half h1 = half(1.0f);
//hvec2 hv2 = hvec2(h1);
//hvec3 hv3 = hvec3(h1);
//hvec4 hv4 = hvec4(h1);
}
vec2 Stuff = glm::mix(vec2(1), vec2(0), 0.5f);
test_gtx_bit();
vec2 Max = glm::max(vec2(0.f), vec2(1.f));
vec2 Truc = radians(vec2(1));
// ivec3 v(1);
// v = operator &=((1 << 0));
ivec3 v(1);
v &= (1 << 0);
vec4 Color = glm::f32_rgba_cast<glm::uint32>(glm::uint32(0));
vec3 Normal = glm::normalizedRand3<float>();
//__hvec3GTX hCos = cos(__hvec3GTX(1.0f));
//__hvec3GTX hNormal = normalizedRand3<detail::thalf>();
//quat Quat;
//Quat = sqrt(Quat);
#if(defined(GLM_SWIZZLE) && GLM_SWIZZLE & GLM_SWIZZLE_FUNC)
vec4 ColorRGBA = vec4(1.0, 0.5, 0.0, 1.0)._xyzw();
#endif//GLM_SWIZZLE
hvec2 v1(1.0f, 2.0f);
hvec2 v2(3.0f, 4.0f);
v2 = v1;
v2 += half(1.0f);
v2 += detail::thalf(1.0f);
v2 = v1 - v2;
half hcos1 = glm::cos(half(1.0));
hvec2 hcos2 = glm::cos(hvec2(1.0));
//test_associated_min_max();
system("pause");
return 0;
}
*/
#define CPUID __asm __emit 0fh __asm __emit 0a2h
#define RDTSC __asm __emit 0fh __asm __emit 031h
unsigned test_sse()
{
glm::mat4 MatA;
MatA[0] = glm::vec4(0.2f, 0.1f, 0.3f, 0.4f);
MatA[1] = glm::vec4(1.0f, 0.3f, 0.2f, 0.3f);
MatA[2] = glm::vec4(3.0f, 2.0f, 0.4f, 0.2f);
MatA[3] = glm::vec4(4.0f, 3.0f, 2.0f, 1.0f);
glm::mat4 MulA;
glm::mat4 InvA;
unsigned cycles;
__m128 MatC[4];
MatC[0] = _mm_setr_ps(0.2f, 0.1f, 0.3f, 0.4f);
MatC[1] = _mm_setr_ps(1.0f, 0.3f, 0.2f, 0.3f);
MatC[2] = _mm_setr_ps(3.0f, 2.0f, 0.4f, 0.2f);
MatC[3] = _mm_setr_ps(4.0f, 3.0f, 2.0f, 1.0f);
__m128 MatR[4];
/*
__asm
{
pushad
CPUID
RDTSC
mov cycles, eax
popad
}
*/
//MulA = MatA * MatA;
//_mm_mul_ps(MatC, MatC, MatR);
//InvA = glm::inverse(MatA);
//_mm_inverse_ps(MatC, MatR);
_mm_inverse_fast_ps(MatC, MatR);
//glm::mat4 IndA = MatA * InvA;
//glm::mat4 InvB = glm::inverseOgre(MatA);
//glm::mat4 IndB = MatA * InvB;
// glm::mat4 InvD = glm::inverseSIMD(MatA);
// glm::mat4 IndD = MatA * InvD;
// glm::mat4 InvE = glm::inverseDev(MatA);
// glm::mat4 IndE = MatA * InvE;
//__m128 MatC[4];
//MatC[0] = _mm_setr_ps(0.2f, 0.1f, 0.3f, 0.4f);
//MatC[1] = _mm_setr_ps(1.0f, 0.3f, 0.2f, 0.3f);
//MatC[2] = _mm_setr_ps(3.0f, 2.0f, 0.4f, 0.2f);
//MatC[3] = _mm_setr_ps(4.0f, 3.0f, 2.0f, 1.0f);
//__m128 InvC[4];
//_mm_inverse_ps(MatC, InvC);
//__m128 IndC[4];
//_mm_mul_ps(MatC, InvC, IndC);
//__m128 Mul2[4];
//_mm_mul_ps(MatC, MatC, Mul2);
/*
__asm
{
pushad
CPUID
RDTSC
sub eax, cycles
mov cycles, eax
popad
}
*/
return cycles;
}
unsigned test_mat4_translate()
{
glm::mat4 MatA;
MatA[0] = glm::vec4(0.2f, 0.1f, 0.3f, 0.4f);
MatA[1] = glm::vec4(1.0f, 0.3f, 0.2f, 0.3f);
MatA[2] = glm::vec4(3.0f, 2.0f, 0.4f, 0.2f);
MatA[3] = glm::vec4(4.0f, 3.0f, 2.0f, 1.0f);
glm::mat4 Transform;
__m128 MatC[4];
MatC[0] = _mm_setr_ps(0.2f, 0.1f, 0.3f, 0.4f);
MatC[1] = _mm_setr_ps(1.0f, 0.3f, 0.2f, 0.3f);
MatC[2] = _mm_setr_ps(3.0f, 2.0f, 0.4f, 0.2f);
MatC[3] = _mm_setr_ps(4.0f, 3.0f, 2.0f, 1.0f);
__m128 MatR[4];
float v[] = {1, 2, 3};
unsigned cycles;
/*
__asm
{
pushad
CPUID
RDTSC
mov cycles, eax
popad
}
*/
_mm_rotate_ps(MatC, 45.f, v, MatR);
//Transform = glm::rotate(MatA, 45.f, glm::vec3(1, 2, 3));
/*
__asm
{
pushad
CPUID
RDTSC
sub eax, cycles
mov cycles, eax
popad
}
*/
return cycles;
}
void test_vec4_simd()
{
glm::vec4SIMD v1(1.0f, 2.0f, 3.0f, 4.0f);
glm::vec4SIMD v2(5.0f, 6.0f, 7.0f, 8.0f);
glm::vec4SIMD v3 = v1 + v2;
bool end = true;
}
bool main_test()
{
bool Result = true;
Result = Result && glm::test::main_bug();
assert(Result);
Result = Result && glm::test::main_type_half();
assert(Result);
Result = Result && glm::test::main_img();
assert(Result);
return true;
}
/*
template<template <typename valType> genType>
valType templateTemplateParameter(genType const & v)
{
valType Result = valType(0);
for(typename gentype::size_type i = 0; i < genType::value_size(); ++i)
{
Result += v[i];
}
return Result;
}
*/
template<class T>
class A1
{
int x;
};
template<template<class T> class U>
class B1
{
};
//#include <glm/glm.hpp>
//void computeFaceNormals(mesh & Mesh)
//{
// for(mesh::iteractor it = Mesh.Faces.begin(); it != Mesh.Faces.end(); ++it)
// {
// glm::vec3 const & a = Mesh.Points[it->Vertices[0].Index].Position;
// glm::vec3 const & b = Mesh.Points[it->Vertices[1].Index].Position;
// glm::vec3 const & c = Mesh.Points[it->Vertices[2].Index].Position;
// it->Normal = glm::normalize(glm::cross(c - a, b - a));
// }
//}
template <std::size_t N, typename T>
struct vecBase
{
typedef T value_type;
typedef std::size_t size_type;
static size_type const value_size;
};
template <std::size_t N, typename T>
typename vecBase<N, T>::size_type const vecBase<N, T>::value_size = N;
template <std::size_t N, typename T>
struct vecDEV : public vecBase<N, T>
{
typedef T value_type;
};
template <typename T>
struct vecDEV<4, T> : public vecBase<4, T>
{
value_type Data[value_size];
};
void main_core_func_integer()
{
std::size_t ValueA = 1;
std::size_t ValueB = glm::bitfieldReverse(ValueA);
assert(ValueA != ValueB);
std::size_t ValueC = glm::bitfieldReverse(ValueB);
assert(ValueA == ValueC);
bool stop = 76;
}
int main()
{
float MuxesA = glm::log2(136.f) * 136.f * 2.f;
float MuxesB = glm::log2(120.f) * 120.f * 2.f;
float Ratio = MuxesB * 100 / MuxesA;
B1<A1> c;
//templateTemplateParameter<glm::detail::tvec3>();
main_core_func_integer();
assert(main_test());
glm::test::main_core_func_common();
glm::test::main_core_func_exponential();
glm::test::main_core_func_geometric();
glm::test::main_core_func_matrix();
glm::test::main_core_func_noise();
glm::test::main_core_func_trigonometric();
glm::test::main_core_func_vector_relational();
glm::test::main_gtx_intesect();
//test_sse_vec4();
//test_sse_mat4();
test_vec4_simd();
glm::quat q;
glm::vec3 v;
glm::vec3 w = glm::cross(q, v);
glm::vec3 u = glm::cross(v, q);
unsigned int base, base1, base2, base3, base4, base5;
unsigned int clock;
// Warm up cpuid & rdtsc
/*
*/
/*
__asm
{
pushad;
cpuid;
rdtsc;
mov clock, eax;
cpuid;
rdtsc;
sub eax, clock;
mov base1, eax;
cpuid;
rdtsc;
mov clock, eax;
cpuid;
rdtsc;
sub eax, clock;
mov base2, eax;
cpuid;
rdtsc;
mov clock, eax;
cpuid;
rdtsc;
sub eax, clock;
mov base3, eax;
cpuid;
rdtsc;
mov clock, eax;
cpuid;
rdtsc;
sub eax, clock;
mov base4, eax;
cpuid;
rdtsc;
mov clock, eax;
cpuid;
rdtsc;
sub eax, clock;
mov base5, eax;
popad;
}
*/
base = base1;
if (base > base2)
base = base2;
if (base > base3)
base = base3;
if (base > base4)
base = base4;
if (base > base5)
base = base5;
{
const unsigned size = 16;
unsigned cycles[size];
for(unsigned i = 0; i < size; ++i)
cycles[i] = test_mat4_translate();//test_sse();
// By the second or third run, both data and instruction
// cache effects should have been eliminated, and results
// will be consistent.
printf("SSE\nBase : %d\n", base);
printf("Cycle counts:\n");
for(unsigned i = 0; i < size; ++i)
printf("%d\n", cycles[i] - base);
}
glm::mat4 m(1.0);
glm::mat4 m1 = m + 2.0f;
system("pause");
}
//#include <glm/glm.hpp> // vec3, vec4, ivec4, mat4
//#include <glm/gtc/matrix_projection.hpp> // glm::perspective
//#include <glm/gtc/matrix_transform.hpp> // glm::translate, glm::rotate, glm::scale
//#include <glm/gtx/type_ptr.hpp> // glm::value_ptr
//
//glm::vec4 const ClearColor(glm::vec3(0.0f), 1.0f);
//glm::ivec4 const Viewport(0, 0, 640, 480);
//
//void render()
//{
// glClearColor(ClearColor.r, ClearColor.g, ClearColor.b, ClearColor.a);
// glClear(GL_COLOR_BUFFER_BIT);
//
// glViewport(Viewport.x, Viewport.y, Viewport.z, Viewport.w);
//
// glm::mat4 Projection = glm::perspective(45.0f, 4.0f / 3.0f, 0.1f, 100.0f);
// glm::mat4 ViewTranslate = glm::translate(glm::vec3(0.0f, 0.0f, -4.0f));
// glm::mat4 ViewRotateX = glm::rotate(ViewTranslate, 45.0f, glm::vec3(-1.0f, 0.0f, 0.0f));
// glm::mat4 View = glm::rotate(ViewRotateX, 45.0f, glm::vec3(0.0f, 1.0f, 0.0f));
// glm::mat4 Model = glm::scale(glm::mat4(1.0f), glm::vec3(0.5f));
//
// glMatrixMode(GL_PROJECTION);
// glLoadMatrixf(glm::value_ptr(Projection));
//
// glMatrixMode(GL_MODELVIEW);
// glLoadMatrixf(glm::value_ptr(View * Model));
//}