| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370 |
- ///////////////////////////////////////////////////////////////////////////////////////////////////
- // OpenGL Mathematics Copyright (c) 2005 - 2010 G-Truc Creation (www.g-truc.net)
- ///////////////////////////////////////////////////////////////////////////////////////////////////
- // Created : 2008-08-31
- // Updated : 2008-08-31
- // Licence : This source is under MIT License
- // File : test/core/func_geometric.cpp
- ///////////////////////////////////////////////////////////////////////////////////////////////////
- #include "../precompiled.hpp"
- #include <glm/core/func_geometric.hpp>
- namespace glm{
- namespace test{
- bool test_length_1()
- {
- float f1 = 0.0f;
- float len1 = length(f1);
- float f2 = 1.0f;
- float len2 = length(f2);
- if (len1 == 0.0f && len2 == 1.0f)
- return true;
- return false;
- }
- bool test_length_2()
- {
- vec2 v1 = vec2(0, 0);
- float len1 = length(v1);
- vec2 v2 = vec2 (1, 1);
- float len2 = length(v2);
- if (len1 == 0.0f && len2 > 1.41f && len2 < 1.42f)
- return true;
- return false;
- }
- bool test_length_3()
- {
- vec3 v1 = vec3(0, 0, 0);
- float len1 = length(v1);
- vec3 v2 = vec3 (1, 1, 1);
- float len2 = length(v2);
- if (len1 == 0.0f && len2 > 1.73f && len2 < 1.74f)
- return true;
- return false;
- }
- bool test_length_4()
- {
- vec4 v1 = vec4(0, 0, 0, 0);
- float len1 = length(v1);
- vec4 v2 = vec4(1, 1, 1, 1);
- float len2 = length(v2);
- if (len1 == 0.0f && len2 == 2.f)
- return true;
- return false;
- }
- bool test_distance_1()
- {
- float p0 = 2.f;
- float p1 = -2.f;
- float dist = distance(p0, p1);
- if (dist == 4.0f)
- return true;
- return false;
- }
- bool test_distance_2()
- {
- vec2 p0 = vec2(0.f, 2.f);
- vec2 p1 = vec2(0.f,-2.f);
- float dist = distance(p0, p1);
- if (dist == 4.0f)
- return true;
- return false;
- }
- bool test_distance_3()
- {
- vec3 p0 = vec3(0.f, 0.f, 2.f);
- vec3 p1 = vec3(0.f, 0.f,-2.f);
- float dist = distance(p0, p1);
- if (dist == 4.0f)
- return true;
- return false;
- }
- bool test_distance_4()
- {
- vec4 p0 = vec4(0.f, 0.f, 2.f, 0.f);
- vec4 p1 = vec4(0.f, 0.f,-2.f, 0.f);
- float dist = distance(p0, p1);
- if (dist == 4.0f)
- return true;
- return false;
- }
- bool test_dot_1()
- {
- float v1 = 1.0f;
- float v2 = 0.0f;
- float dot1 = dot (v1, v1);
- float dot2 = dot (v1, v2);
- if (dot1 == 1.0f && dot2 == 0.0f)
- return true;
- return false;
- }
- bool test_dot_2()
- {
- vec2 v1 = vec2 (1, 0);
- vec2 v2 = vec2 (0, 1);
- float dot1 = dot (v1, v1);
- float dot2 = dot (v1, v2);
- if (dot1 == 1.0f && dot2 == 0.0f)
- return true;
- return false;
- }
- bool test_dot_3()
- {
- vec3 v1 = vec3 (1, 0, 0);
- vec3 v2 = vec3 (0, 1, 0);
- float dot1 = dot (v1, v1);
- float dot2 = dot (v1, v2);
- if (dot1 == 1.0f && dot2 == 0.0f)
- return true;
- return false;
- }
- bool test_dot_4()
- {
- vec4 v1 = vec4 (1, 0, 0, 0);
- vec4 v2 = vec4 (0, 1, 0, 0);
- float dot1 = dot (v1, v1);
- float dot2 = dot (v1, v2);
- if (dot1 == 1.0f && dot2 == 0.0f)
- return true;
- return false;
- }
- bool test_cross_vec3 ()
- {
- vec3 v1 = vec3(1.0f, 0.0f, 0.0f);
- vec3 v2 = vec3(0.0f, 1.0f, 0.0f);
- vec3 v3 = cross(v1, v2);
- vec3 v4 = vec3(0.0f, 0.0f, 1.0f);
- if (v3.x == v4.x && v3.y == v4.y && v3.z == v4.z)
- return true;
- return false;
- }
- bool test_normalize_1()
- {
- float f1 = 0.0f;
- f1 = normalize(f1);
- float f2 = 1.0f;
- f2 = normalize(f2);
- if (f1 == 1.0f && f2 == 1.0f)
- return true;
- return false;
- }
- bool test_normalize_2()
- {
- vec2 v1 = vec2(0, 0);
- v1 = normalize(v1);
- vec2 v2 = vec2 (1, 1);
- v2 = normalize(v2);
- if (length (v2) > 0.99f && length (v2) < 1.01f)
- return true;
- return false;
- }
- bool test_normalize_3()
- {
- vec3 v1 = vec3(0, 0, 0);
- v1 = normalize(v1);
- vec3 v2 = vec3(1, 1, 1);
- v2 = normalize(v2);
- if (length (v2) > 0.99f && length (v2) < 1.01f)
- return true;
- return false;
- }
- bool test_normalize_4()
- {
- vec4 v1 = vec4(0, 0, 0, 0);
- v1 = normalize(v1);
- vec4 v2 = vec4(1, 1, 1, 1);
- v2 = normalize(v2);
- if (length (v2) > 0.99f && length (v2) < 1.01f)
- return true;
- return false;
- }
- bool test_faceforward_1()
- {
- float N = 1.0f;
- float I = 1.0f;
- float Nref = 1.0f;
- N = faceforward(N, I, Nref);
- if (N == -1)
- return true;
- return false;
- }
- bool test_faceforward_2()
- {
- vec2 N = vec2(1, 1);
- vec2 I = vec2(1, 0);
- vec2 Nref = vec2(0, 0);
- N = faceforward(N, I, Nref);
- if (N.x == -1 && N.y == -1)
- return true;
- return false;
- }
- bool test_faceforward_3()
- {
- vec3 N = vec3(1, 1, 1);
- vec3 I = vec3(1, 0, 0);
- vec3 Nref = vec3(0, 0, 0);
- N = faceforward(N, I, Nref);
- if (N.x == -1 && N.y == -1 && N.z == -1)
- return true;
- return false;
- }
- bool test_faceforward_4()
- {
- vec4 N = vec4(1, 1, 1, 1);
- vec4 I = vec4(1, 0, 0, 0);
- vec4 Nref = vec4(0, 0, 0, 0);
- N = faceforward(N, I, Nref);
- if (N.x == -1 && N.y == -1 && N.z == -1 && N.w == -1)
- return true;
- return false;
- }
- bool test_reflect_2()
- {
- vec2 N = vec2( 1, 0);
- vec2 I = vec2(-1, 0);
- vec2 result = reflect(I, N);
- if (result.x != 1.0f || result.y != 0.f)
- return false;
- return true;
- }
- bool test_reflect_3()
- {
- vec3 N = vec3( 1, 0, 0);
- vec3 I = vec3(-1, 0, 0);
- vec3 result = reflect(I, N);
- if (result.x != 1.0f || result.y != 0.f || result.z != 0.f)
- return false;
- return true;
- }
- bool test_reflect_4()
- {
- vec4 N = vec4( 1, 0, 0, 0);
- vec4 I = vec4(-1, 0, 0, 0);
- vec4 result = reflect(I, N);
- if (result.x != 1.0f || result.y != 0.f || result.z != 0.f || result.w != 0.f)
- return false;
- return true;
- }
- bool test_refract_2()
- {
- glm::vec2 N = glm::vec2( 1, 0);
- glm::vec2 I = glm::vec2(-1, 0);
- glm::vec2 result = glm::refract(I, N, 1.0f);
- if (result.x != -1.f || result.y != 0.f)
- return false;
- return true;
- }
- bool test_refract_3()
- {
- glm::vec3 N = glm::vec3( 1, 0, 0);
- glm::vec3 I = glm::vec3(-1, 0, 0);
- glm::vec3 result = glm::refract(I, N, 1.0f);
- if (result.x != -1.f || result.y != 0.f || result.z != 0.f)
- return false;
- return true;
- }
- bool test_refract_4()
- {
- glm::vec4 N = glm::vec4( 1, 0, 0, 0);
- glm::vec4 I = glm::vec4(-1, 0, 0, 0);
- glm::vec4 result = glm::refract(I, N, 1.0f);
- if (result.x != -1.f || result.y != 0.f || result.z != 0.f || result.w != 0.f)
- return false;
- return true;
- }
- void main_core_func_geometric()
- {
- assert(test_length_1());
- assert(test_length_2());
- assert(test_length_3());
- assert(test_length_4());
- assert(test_distance_1());
- assert(test_distance_2());
- assert(test_distance_3());
- assert(test_distance_4());
- assert(test_dot_1());
- assert(test_dot_2());
- assert(test_dot_3());
- assert(test_dot_4());
- assert(test_cross_vec3());
- assert(test_normalize_1());
- assert(test_normalize_2());
- assert(test_normalize_3());
- assert(test_normalize_4());
- assert(test_faceforward_1());
- assert(test_faceforward_2());
- assert(test_faceforward_3());
- assert(test_faceforward_4());
-
- assert(test_reflect_2());
- assert(test_reflect_3());
- assert(test_reflect_4());
- assert(test_refract_2());
- assert(test_refract_3());
- assert(test_refract_4());
- }
- }//namespace test
- }//namespace glm
|