swizzle3_test.cpp 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. //Copyright (c) 2008-2016 Emil Dotchevski and Reverge Studios, Inc.
  2. //Distributed under the Boost Software License, Version 1.0. (See accompanying
  3. //file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  4. #include <boost/qvm/vec_operations.hpp>
  5. #include <boost/qvm/vec_access.hpp>
  6. #include <boost/qvm/vec.hpp>
  7. #include <boost/qvm/swizzle.hpp>
  8. #include "test_qvm_vector.hpp"
  9. int
  10. main()
  11. {
  12. using namespace boost::qvm;
  13. test_qvm::vector<V1,4> v1;
  14. v1.a[0]=42.0f;
  15. v1.a[1]=43.0f;
  16. v1.a[2]=44.0f;
  17. v1.a[3]=45.0f;
  18. XXX(v1) + XXX(v1);
  19. -XXX(v1);
  20. XXX(42.0f) + XXX(42.0f);
  21. -XXX(42.0f);
  22. {
  23. test_qvm::vector<V2,3> v0=X00(42.0f);
  24. BOOST_TEST(v0.a[0]==42);
  25. BOOST_TEST(v0.a[1]==0);
  26. BOOST_TEST(v0.a[2]==0);
  27. test_qvm::vector<V2,3> v2=_10X(42.0f);
  28. BOOST_TEST(v2.a[0]==1);
  29. BOOST_TEST(v2.a[1]==0);
  30. BOOST_TEST(v2.a[2]==42);
  31. float s=42.0f;
  32. BOOST_TEST(&X(X01(s))==&s);
  33. }
  34. {
  35. test_qvm::vector<V2,3> r;
  36. r.a[0]=v1.a[0];
  37. r.a[1]=v1.a[0];
  38. r.a[2]=v1.a[0];
  39. test_qvm::vector<V2,3> v2=XXX(v1);
  40. BOOST_QVM_TEST_EQ(v2,r);
  41. }
  42. {
  43. test_qvm::vector<V2,3> r;
  44. r.a[0]=v1.a[0];
  45. r.a[1]=v1.a[0];
  46. r.a[2]=v1.a[1];
  47. test_qvm::vector<V2,3> v2=XXY(v1);
  48. BOOST_QVM_TEST_EQ(v2,r);
  49. }
  50. {
  51. test_qvm::vector<V2,3> r;
  52. r.a[0]=v1.a[0];
  53. r.a[1]=v1.a[0];
  54. r.a[2]=v1.a[2];
  55. test_qvm::vector<V2,3> v2=XXZ(v1);
  56. BOOST_QVM_TEST_EQ(v2,r);
  57. }
  58. {
  59. test_qvm::vector<V2,3> r;
  60. r.a[0]=v1.a[0];
  61. r.a[1]=v1.a[0];
  62. r.a[2]=v1.a[3];
  63. test_qvm::vector<V2,3> v2=XXW(v1);
  64. BOOST_QVM_TEST_EQ(v2,r);
  65. }
  66. {
  67. test_qvm::vector<V2,3> r;
  68. r.a[0]=v1.a[0];
  69. r.a[1]=v1.a[0];
  70. r.a[2]=0;
  71. test_qvm::vector<V2,3> v2=XX0(v1);
  72. BOOST_QVM_TEST_EQ(v2,r);
  73. }
  74. {
  75. test_qvm::vector<V2,3> r;
  76. r.a[0]=v1.a[0];
  77. r.a[1]=v1.a[0];
  78. r.a[2]=1;
  79. test_qvm::vector<V2,3> v2=XX1(v1);
  80. BOOST_QVM_TEST_EQ(v2,r);
  81. }
  82. {
  83. test_qvm::vector<V2,3> v2=XYZ(v1);
  84. XYZ(v1) *= 2;
  85. v2 *= 2;
  86. test_qvm::vector<V2,3> v3=XYZ(v1);
  87. BOOST_QVM_TEST_EQ(v2,v3);
  88. }
  89. {
  90. test_qvm::vector<V2,3> v2=XYZ(v1);
  91. test_qvm::vector<V3,3> v3;
  92. XYZ(v3)=XYZ(v2);
  93. BOOST_QVM_TEST_EQ(v2,v3);
  94. }
  95. {
  96. test_qvm::vector<V1,3> v=_000();
  97. BOOST_TEST(v.a[0]==0);
  98. BOOST_TEST(v.a[1]==0);
  99. BOOST_TEST(v.a[2]==0);
  100. }
  101. {
  102. test_qvm::vector<V1,3> v=_001();
  103. BOOST_TEST(v.a[0]==0);
  104. BOOST_TEST(v.a[1]==0);
  105. BOOST_TEST(v.a[2]==1);
  106. }
  107. {
  108. test_qvm::vector<V1,3> v=_010();
  109. BOOST_TEST(v.a[0]==0);
  110. BOOST_TEST(v.a[1]==1);
  111. BOOST_TEST(v.a[2]==0);
  112. }
  113. {
  114. test_qvm::vector<V1,3> v=_011();
  115. BOOST_TEST(v.a[0]==0);
  116. BOOST_TEST(v.a[1]==1);
  117. BOOST_TEST(v.a[2]==1);
  118. }
  119. {
  120. test_qvm::vector<V1,3> v=_100();
  121. BOOST_TEST(v.a[0]==1);
  122. BOOST_TEST(v.a[1]==0);
  123. BOOST_TEST(v.a[2]==0);
  124. }
  125. {
  126. test_qvm::vector<V1,3> v=_101();
  127. BOOST_TEST(v.a[0]==1);
  128. BOOST_TEST(v.a[1]==0);
  129. BOOST_TEST(v.a[2]==1);
  130. }
  131. {
  132. test_qvm::vector<V1,3> v=_110();
  133. BOOST_TEST(v.a[0]==1);
  134. BOOST_TEST(v.a[1]==1);
  135. BOOST_TEST(v.a[2]==0);
  136. }
  137. {
  138. test_qvm::vector<V1,3> v=_111();
  139. BOOST_TEST(v.a[0]==1);
  140. BOOST_TEST(v.a[1]==1);
  141. BOOST_TEST(v.a[2]==1);
  142. }
  143. return boost::report_errors();
  144. }