gtx_norm.cpp 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. #define GLM_ENABLE_EXPERIMENTAL
  2. #include <glm/gtx/norm.hpp>
  3. int test_lMaxNorm()
  4. {
  5. int Error(0);
  6. {
  7. float norm = glm::lMaxNorm(glm::vec3(-1, -2, -3));
  8. Error += glm::epsilonEqual(norm, 3.f, 0.00001f) ? 0 : 1;
  9. }
  10. {
  11. float norm = glm::lMaxNorm(glm::vec3(2, 3, 1));
  12. Error += glm::epsilonEqual(norm, 3.f, 0.00001f) ? 0 : 1;
  13. }
  14. return Error;
  15. }
  16. int test_lxNorm()
  17. {
  18. int Error(0);
  19. {
  20. unsigned int depth_1 = 1;
  21. float normA = glm::lxNorm(glm::vec3(2, 3, 1), depth_1);
  22. float normB = glm::l1Norm(glm::vec3(2, 3, 1));
  23. Error += glm::epsilonEqual(normA, normB, 0.00001f) ? 0 : 1;
  24. Error += glm::epsilonEqual(normA, 6.f, 0.00001f) ? 0 : 1;
  25. }
  26. {
  27. unsigned int depth_1 = 1;
  28. float normA = glm::lxNorm(glm::vec3(-1, -2, -3), depth_1);
  29. float normB = glm::l1Norm(glm::vec3(-1, -2, -3));
  30. Error += glm::epsilonEqual(normA, normB, 0.00001f) ? 0 : 1;
  31. Error += glm::epsilonEqual(normA, 6.f, 0.00001f) ? 0 : 1;
  32. }
  33. {
  34. unsigned int depth_2 = 2;
  35. float normA = glm::lxNorm(glm::vec3(2, 3, 1), depth_2);
  36. float normB = glm::l2Norm(glm::vec3(2, 3, 1));
  37. Error += glm::epsilonEqual(normA, normB, 0.00001f) ? 0 : 1;
  38. Error += glm::epsilonEqual(normA, 3.741657387f, 0.00001f) ? 0 : 1;
  39. }
  40. {
  41. unsigned int depth_2 = 2;
  42. float normA = glm::lxNorm(glm::vec3(-1, -2, -3), depth_2);
  43. float normB = glm::l2Norm(glm::vec3(-1, -2, -3));
  44. Error += glm::epsilonEqual(normA, normB, 0.00001f) ? 0 : 1;
  45. Error += glm::epsilonEqual(normA, 3.741657387f, 0.00001f) ? 0 : 1;
  46. }
  47. {
  48. unsigned int oddDepth = 3;
  49. float norm = glm::lxNorm(glm::vec3(2, 3, 1), oddDepth);
  50. Error += glm::epsilonEqual(norm, 3.301927249f, 0.00001f) ? 0 : 1;
  51. }
  52. {
  53. unsigned int oddDepth = 3;
  54. float norm = glm::lxNorm(glm::vec3(-1, -2, -3), oddDepth);
  55. Error += glm::epsilonEqual(norm, 3.301927249f, 0.00001f) ? 0 : 1;
  56. }
  57. return Error;
  58. }
  59. int main()
  60. {
  61. int Error(0);
  62. Error += test_lMaxNorm();
  63. Error += test_lxNorm();
  64. return Error;
  65. }