test_dimensionless_quantity.cpp 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. // Boost.Units - A C++ library for zero-overhead dimensional analysis and
  2. // unit/quantity manipulation and conversion
  3. //
  4. // Copyright (C) 2003-2008 Matthias Christian Schabel
  5. // Copyright (C) 2008 Steven Watanabe
  6. //
  7. // Distributed under the Boost Software License, Version 1.0. (See
  8. // accompanying file LICENSE_1_0.txt or copy at
  9. // http://www.boost.org/LICENSE_1_0.txt)
  10. /**
  11. \file
  12. \brief test_dimensionless_quantity.cpp
  13. \details
  14. Test unit class.
  15. Output:
  16. @verbatim
  17. @endverbatim
  18. **/
  19. #include "test_header.hpp"
  20. #include <boost/units/pow.hpp>
  21. namespace bu = boost::units;
  22. BOOST_STATIC_CONSTEXPR double E_ = 2.718281828459045235360287471352662497757;
  23. int test_main(int,char *[])
  24. {
  25. // default constructor
  26. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> E1;
  27. BOOST_CHECK(E1.value() == double());
  28. // value_type constructor
  29. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> E2(E_);
  30. BOOST_CHECK(E2.value() == E_);
  31. // copy constructor
  32. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> E3(E2);
  33. BOOST_CHECK(E3.value() == E_);
  34. // operator=
  35. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> E4 = E2;
  36. BOOST_CHECK(E4.value() == E_);
  37. // implicit copy constructor value_type conversion
  38. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless,float> E5(E2);
  39. BOOST_UNITS_CHECK_CLOSE(E5.value(), float(E_));
  40. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless,long> E6(E2);
  41. BOOST_CHECK(E6.value() == long(E_));
  42. // implicit operator= value_type conversion
  43. // narrowing conversion disallowed
  44. // BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless,float> E7 = E2;
  45. // BOOST_UNITS_CHECK_CLOSE(E7.value(),float(E_));
  46. // narrowing conversion disallowed
  47. // BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless,long> E8 = E2;
  48. // BOOST_CHECK(E8.value() == long(E_));
  49. // const construction
  50. bu::quantity<bu::dimensionless> E9(E2);
  51. BOOST_CHECK(E9.value() == E_);
  52. // // value assignment
  53. // E9.value() = 1.5*bu::dimensionless();
  54. // BOOST_CHECK(E9.value() == 1.5);
  55. //
  56. // // value assignment with implicit conversion
  57. // E9.value() = 1.5;
  58. // BOOST_CHECK(E9.value() == 1.5);
  59. //
  60. // // value assignment with implicit value_type conversion
  61. // E9.value() = 2*bu::dimensionless();
  62. // BOOST_CHECK(E9.value() == double(2));
  63. //
  64. // // value assignment with implicit value_type conversion
  65. // E9.value() = 2;
  66. // BOOST_CHECK(E9.value() == double(2));
  67. // operator+=(this_type)
  68. E9 = 2.0;
  69. E9 += E9;
  70. BOOST_CHECK(E9.value() == 4.0);
  71. // operator-=(this_type)
  72. E9 = 2.0;
  73. E9 -= E9;
  74. BOOST_CHECK(E9.value() == 0.0);
  75. // operator*=(value_type)
  76. E9 = 2.0;
  77. E9 *= 2.0;
  78. BOOST_CHECK(E9.value() == 4.0);
  79. // operator/=(value_type)
  80. E9 = 2.0;
  81. E9 /= 2.0;
  82. BOOST_CHECK(E9.value() == 1.0);
  83. // static construct quantity from value_type
  84. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> E(bu::quantity<bu::dimensionless>::from_value(2.5));
  85. BOOST_CHECK(E.value() == 2.5);
  86. // implicit conversion to value_type
  87. const double V1(E9);
  88. BOOST_CHECK(V1 == E9.value());
  89. const double V2 = E9;
  90. BOOST_CHECK(V2 == E9.value());
  91. // unit * scalar
  92. BOOST_CHECK(bu::dimensionless()*2.0 == bu::quantity<bu::dimensionless>::from_value(2.0));
  93. // unit / scalar
  94. BOOST_CHECK(bu::dimensionless()/2.0 == bu::quantity<bu::dimensionless>::from_value(0.5));
  95. // scalar * unit
  96. BOOST_CHECK(2.0*bu::dimensionless() == bu::quantity<bu::dimensionless>::from_value(2.0));
  97. // scalar / unit
  98. BOOST_CHECK(2.0/bu::dimensionless() == bu::quantity<bu::dimensionless>::from_value(2.0));
  99. // quantity * scalar
  100. BOOST_CHECK(E*2.0 == bu::quantity<bu::dimensionless>::from_value(5.0));
  101. // quantity / scalar
  102. BOOST_CHECK(E/2.0 == bu::quantity<bu::dimensionless>::from_value(1.25));
  103. // scalar * quantity
  104. BOOST_CHECK(2.0*E == bu::quantity<bu::dimensionless>::from_value(5.0));
  105. // scalar / quantity
  106. BOOST_CHECK(2.0/E == bu::quantity<bu::dimensionless>::from_value(0.8));
  107. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> D1(1.0),
  108. D2(2.0);
  109. // unit * quantity
  110. BOOST_CHECK(bu::dimensionless()*D1 == D1);
  111. // unit / quantity
  112. BOOST_CHECK(bu::dimensionless()/D1 == D1);
  113. // quantity * unit
  114. BOOST_CHECK(D1*bu::dimensionless() == D1);
  115. // quantity / unit
  116. BOOST_CHECK(D1*bu::dimensionless() == D1);
  117. // +quantity
  118. BOOST_CHECK(+D1 == 1.0*bu::dimensionless());
  119. // -quantity
  120. BOOST_CHECK(-D1 == -1.0*bu::dimensionless());
  121. // quantity + quantity
  122. BOOST_CHECK(D2+D1 == 3.0*bu::dimensionless());
  123. // quantity - quantity
  124. BOOST_CHECK(D2-D1 == 1.0*bu::dimensionless());
  125. // quantity * quantity
  126. BOOST_CHECK(D1*D2 == 2.0*bu::dimensionless());
  127. // quantity / quantity
  128. BOOST_CHECK(D2/D1 == 2.0*bu::dimensionless());
  129. // integer power of quantity
  130. BOOST_CHECK(2.0*bu::pow<2>(D2) == 2.0*std::pow(2.0,2.0)*bu::dimensionless());
  131. // rational power of quantity
  132. BOOST_CHECK((2.0*bu::pow< bu::static_rational<2,3> >(D2) == 2.0*std::pow(2.0,2.0/3.0)*bu::dimensionless()));
  133. // integer root of quantity
  134. BOOST_CHECK(2.0*bu::root<2>(D2) == 2.0*std::pow(2.0,1.0/2.0)*bu::dimensionless());
  135. // rational root of quantity
  136. BOOST_CHECK((2.0*bu::root< bu::static_rational<3,2> >(D2) == 2.0*std::pow(2.0,2.0/3.0)*bu::dimensionless()));
  137. BOOST_CONSTEXPR_OR_CONST bu::quantity<bu::dimensionless> A1(0.0),
  138. A2(0.0),
  139. A3(1.0),
  140. A4(-1.0);
  141. // operator==
  142. BOOST_CHECK((A1 == A2) == true);
  143. BOOST_CHECK((A1 == A3) == false);
  144. // operator!=
  145. BOOST_CHECK((A1 != A2) == false);
  146. BOOST_CHECK((A1 != A3) == true);
  147. // operator<
  148. BOOST_CHECK((A1 < A2) == false);
  149. BOOST_CHECK((A1 < A3) == true);
  150. // operator<=
  151. BOOST_CHECK((A1 <= A2) == true);
  152. BOOST_CHECK((A1 <= A3) == true);
  153. // operator>
  154. BOOST_CHECK((A1 > A2) == false);
  155. BOOST_CHECK((A1 > A4) == true);
  156. // operator>=
  157. BOOST_CHECK((A1 >= A2) == true);
  158. BOOST_CHECK((A1 >= A4) == true);
  159. return 0;
  160. }