scoped_channel_value.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. //
  2. // Copyright 2005-2007 Adobe Systems Incorporated
  3. // Copyright 2018 Mateusz Loskot <mateusz at loskot dot net>
  4. //
  5. // Distribtted under the Boost Software License, Version 1.0
  6. // See accompanying file LICENSE_1_0.txt or copy at
  7. // http://www.boost.org/LICENSE_1_0.txt
  8. //
  9. #include <boost/gil/channel.hpp>
  10. #include <boost/gil/channel_algorithm.hpp>
  11. #include <boost/gil/typedefs.hpp>
  12. #include <cstdint>
  13. #include <limits>
  14. #define BOOST_TEST_MODULE test_scoped_channel_value
  15. #include "unit_test.hpp"
  16. namespace gil = boost::gil;
  17. struct int_minus_value { static std::int8_t apply() { return -64; } };
  18. struct int_plus_value { static std::int8_t apply() { return 64; } };
  19. using fixture = gil::scoped_channel_value
  20. <
  21. std::uint8_t, int_minus_value, int_plus_value
  22. >;
  23. BOOST_AUTO_TEST_CASE(scoped_channel_value_default_constructor)
  24. {
  25. fixture f;
  26. std::uint8_t v = f;
  27. BOOST_TEST(v == std::uint8_t{0});
  28. }
  29. BOOST_AUTO_TEST_CASE(scoped_channel_value_user_defined_constructors)
  30. {
  31. fixture f{1};
  32. std::uint8_t v = f;
  33. BOOST_TEST(v == std::uint8_t{1});
  34. }
  35. BOOST_AUTO_TEST_CASE(scoped_channel_value_copy_constructors)
  36. {
  37. fixture f1{128};
  38. fixture f2{f1};
  39. BOOST_TEST(std::uint8_t{f1} == std::uint8_t{128});
  40. BOOST_TEST(std::uint8_t{f1} == std::uint8_t{f2});
  41. }
  42. BOOST_AUTO_TEST_CASE(scoped_channel_value_assignment)
  43. {
  44. fixture f;
  45. f = 64;
  46. std::uint8_t v = f;
  47. BOOST_TEST(v == std::uint8_t{64});
  48. }
  49. BOOST_AUTO_TEST_CASE(scoped_channel_value_float32_t)
  50. {
  51. auto const tolerance = btt::tolerance(std::numeric_limits<float>::epsilon());
  52. // min
  53. BOOST_TEST(gil::float_point_zero<float>::apply() == 0.0, tolerance);
  54. BOOST_TEST(gil::channel_traits<gil::float32_t>::min_value() == 0.0);
  55. // max
  56. BOOST_TEST(gil::float_point_one<float>::apply() == 1.0, tolerance);
  57. BOOST_TEST(gil::channel_traits<gil::float32_t>::max_value() == 1.0);
  58. }
  59. BOOST_AUTO_TEST_CASE(scoped_channel_value_float64_t)
  60. {
  61. auto const tolerance = btt::tolerance(std::numeric_limits<double>::epsilon());
  62. // min
  63. BOOST_TEST(gil::float_point_zero<double>::apply() == 0.0, tolerance);
  64. BOOST_TEST(gil::channel_traits<gil::float64_t>::min_value() == 0.0, tolerance);
  65. // max
  66. BOOST_TEST(gil::float_point_one<double>::apply() == 1.0, tolerance);
  67. BOOST_TEST(gil::channel_traits<gil::float64_t>::max_value() == 1.0, tolerance);
  68. }
  69. BOOST_AUTO_TEST_CASE(scoped_channel_value_halfs)
  70. {
  71. // Create a double channel with range [-0.5 .. 0.5]
  72. struct minus_half { static double apply() { return -0.5; } };
  73. struct plus_half { static double apply() { return 0.5; } };
  74. using halfs = gil::scoped_channel_value<double, minus_half, plus_half>;
  75. auto const tolerance = btt::tolerance(std::numeric_limits<double>::epsilon());
  76. BOOST_TEST(gil::channel_traits<halfs>::min_value() == minus_half::apply(), tolerance);
  77. BOOST_TEST(gil::channel_traits<halfs>::max_value() == plus_half::apply(), tolerance);
  78. // scoped channel maximum should map to the maximum
  79. BOOST_TEST(gil::channel_convert<std::uint16_t>(
  80. gil::channel_traits<halfs>::max_value()) == 65535, tolerance);
  81. }