algorithm_channel_convert.cpp 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. //
  2. // Copyright 2005-2007 Adobe Systems Incorporated
  3. // Copyright 2018 Mateusz Loskot <mateusz at loskot dot net>
  4. //
  5. // Distributed 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_algorithm.hpp>
  10. #include <cstdint>
  11. #define BOOST_TEST_MODULE test_algorithm_channel_convert
  12. #include "unit_test.hpp"
  13. #include "test_fixture.hpp"
  14. namespace gil = boost::gil;
  15. namespace fixture = boost::gil::test::fixture;
  16. template <typename ChannelFixtureBase>
  17. struct test_convert_to
  18. {
  19. using channel_t = typename fixture::channel<ChannelFixtureBase>::channel_t;
  20. using channel_value_t = typename fixture::channel<ChannelFixtureBase>::channel_value_t;
  21. template <typename Channel>
  22. static void from(Channel src_min_v, Channel src_max_v)
  23. {
  24. channel_value_t min_v = gil::channel_convert<channel_t>(src_min_v);
  25. channel_value_t max_v = gil::channel_convert<channel_t>(src_max_v);
  26. fixture::channel_minmax_value<channel_value_t> expect;
  27. BOOST_TEST(min_v == expect.min_v_);
  28. BOOST_TEST(max_v == expect.max_v_);
  29. }
  30. };
  31. //--- Test gil::channel_convert from integral channels to all byte channels -------------
  32. #define GIL_TEST_CHANNEL_CONVERT_FROM(source_channel_type) \
  33. BOOST_FIXTURE_TEST_SUITE( \
  34. channel_convert_from_##source_channel_type, \
  35. fixture::channel_minmax_value<std::source_channel_type>) \
  36. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_value, Channel, fixture::channel_byte_types) \
  37. { test_convert_to<fixture::channel_value<Channel>>::from(min_v_, max_v_); } \
  38. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_reference, Channel, fixture::channel_byte_types) \
  39. { test_convert_to<fixture::channel_reference<Channel&>>::from(min_v_, max_v_); } \
  40. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_reference_const, Channel, fixture::channel_byte_types) \
  41. { test_convert_to<fixture::channel_reference<Channel const&>>::from(min_v_, max_v_); } \
  42. BOOST_AUTO_TEST_CASE(packed_channel_reference) \
  43. { \
  44. using channels565_t = fixture::packed_channels565<std::uint16_t>; \
  45. test_convert_to<typename channels565_t::fixture_0_5_t>::from(min_v_, max_v_); \
  46. test_convert_to<typename channels565_t::fixture_5_6_t>::from(min_v_, max_v_); \
  47. test_convert_to<typename channels565_t::fixture_11_5_t>::from(min_v_, max_v_); \
  48. } \
  49. BOOST_AUTO_TEST_CASE(packed_dynamic_channel_reference) \
  50. { \
  51. using channels565_t = fixture::packed_dynamic_channels565<std::uint16_t>; \
  52. test_convert_to<typename channels565_t::fixture_5_t>::from(min_v_, max_v_); \
  53. test_convert_to<typename channels565_t::fixture_6_t>::from(min_v_, max_v_); \
  54. } \
  55. BOOST_AUTO_TEST_SUITE_END()
  56. GIL_TEST_CHANNEL_CONVERT_FROM(uint8_t)
  57. GIL_TEST_CHANNEL_CONVERT_FROM(int8_t)
  58. GIL_TEST_CHANNEL_CONVERT_FROM(uint16_t)
  59. GIL_TEST_CHANNEL_CONVERT_FROM(int16_t)
  60. GIL_TEST_CHANNEL_CONVERT_FROM(uint32_t)
  61. GIL_TEST_CHANNEL_CONVERT_FROM(int32_t)
  62. #undef GIL_TEST_CHANNEL_CONVERT_FROM
  63. // FIXME: gil::float32_t <-> gil::float64_t seems not supported
  64. //--- Test gil::channel_convert from gil::float32_t to all integer channels -------------
  65. BOOST_FIXTURE_TEST_SUITE(channel_convert_from_float32_t,
  66. fixture::channel_minmax_value<gil::float32_t>)
  67. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_value, Channel, fixture::channel_integer_types)
  68. {
  69. test_convert_to<fixture::channel_value<Channel>>::from(min_v_, max_v_);
  70. }
  71. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_reference, Channel, fixture::channel_integer_types)
  72. {
  73. test_convert_to<fixture::channel_reference<Channel&>>::from(min_v_, max_v_);
  74. }
  75. BOOST_AUTO_TEST_CASE_TEMPLATE(
  76. channel_reference_const, Channel, fixture::channel_integer_types)
  77. {
  78. test_convert_to<fixture::channel_reference<Channel const&>>::from(min_v_, max_v_);
  79. }
  80. BOOST_AUTO_TEST_SUITE_END()
  81. //--- Test gil::channel_convert from gil::float64_t to all integer channels -------------
  82. BOOST_FIXTURE_TEST_SUITE(channel_convert_from_float64_t,
  83. fixture::channel_minmax_value<gil::float64_t>)
  84. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_value, Channel, fixture::channel_integer_types)
  85. {
  86. test_convert_to<fixture::channel_value<Channel>>::from(min_v_, max_v_);
  87. }
  88. BOOST_AUTO_TEST_CASE_TEMPLATE(channel_reference, Channel, fixture::channel_integer_types)
  89. {
  90. test_convert_to<fixture::channel_reference<Channel&>>::from(min_v_, max_v_);
  91. }
  92. BOOST_AUTO_TEST_CASE_TEMPLATE(
  93. channel_reference_const, Channel, fixture::channel_integer_types)
  94. {
  95. test_convert_to<fixture::channel_reference<Channel const&>>::from(min_v_, max_v_);
  96. }
  97. BOOST_AUTO_TEST_SUITE_END()