Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

108 строки
2.2 KiB

  1. //
  2. // Lol Engine
  3. //
  4. // Copyright: (c) 2010-2014 Sam Hocevar <sam@hocevar.net>
  5. // This program is free software; you can redistribute it and/or
  6. // modify it under the terms of the Do What The Fuck You Want To
  7. // Public License, Version 2, as published by Sam Hocevar. See
  8. // http://www.wtfpl.net/ for more details.
  9. //
  10. #include <lol/engine-internal.h>
  11. #include <lolunit.h>
  12. namespace lol
  13. {
  14. lolunit_declare_fixture(ComplexTest)
  15. {
  16. void SetUp() {}
  17. void TearDown() {}
  18. lolunit_declare_test(Equality)
  19. {
  20. cmplx a2(1.0f, 2.0f);
  21. cmplx b2(0.0f, 2.0f);
  22. cmplx c2(1.0f, 0.0f);
  23. lolunit_assert_equal(a2, a2);
  24. lolunit_assert_not_different(a2, a2);
  25. lolunit_assert_different(a2, b2);
  26. lolunit_assert_not_equal(a2, b2);
  27. lolunit_assert_different(a2, c2);
  28. lolunit_assert_not_equal(a2, c2);
  29. }
  30. lolunit_declare_test(UnaryMinus)
  31. {
  32. cmplx a(1.0f, 3.0f);
  33. cmplx b(-1.0f, -3.0f);
  34. lolunit_assert_equal(a, -b);
  35. lolunit_assert_equal(-a, b);
  36. }
  37. lolunit_declare_test(Conjugate)
  38. {
  39. cmplx a(1.0f, 3.0f);
  40. cmplx b(1.0f, -3.0f);
  41. lolunit_assert_equal(a, ~b);
  42. lolunit_assert_equal(~a, b);
  43. }
  44. lolunit_declare_test(Norm)
  45. {
  46. cmplx a(3.0f, -4.0f);
  47. lolunit_assert_equal(norm(a), 5.0f);
  48. cmplx b = a * ~a;
  49. cmplx c = norm(a) * norm(a);
  50. lolunit_assert_equal(b, c);
  51. cmplx d(5.0f, 12.0f);
  52. lolunit_assert_equal(norm(d), 13.0f);
  53. lolunit_assert_equal(norm(a * d), norm(a) * norm(d));
  54. }
  55. lolunit_declare_test(Base)
  56. {
  57. cmplx one(1.0f, 0.0f);
  58. cmplx i(0.0f, 1.0f);
  59. lolunit_assert_equal(norm(one), 1.0f);
  60. lolunit_assert_equal(norm(i), 1.0f);
  61. lolunit_assert_equal(i * i, -one);
  62. }
  63. lolunit_declare_test(Normalize)
  64. {
  65. cmplx a(3.0f, -4.0f);
  66. cmplx b = normalize(a);
  67. lolunit_assert_doubles_equal(norm(b), 1.0, 1e-8);
  68. }
  69. lolunit_declare_test(Reciprocal)
  70. {
  71. cmplx a(3.0f, -4.0f);
  72. cmplx b = re(a);
  73. lolunit_assert_equal(a * b, b * a);
  74. cmplx c = 1.0f;
  75. lolunit_assert_equal(a * b, c);
  76. }
  77. };
  78. } /* namespace lol */