summaryrefslogtreecommitdiffstats
path: root/src/boost/libs/gil/test/legacy
diff options
context:
space:
mode:
Diffstat (limited to 'src/boost/libs/gil/test/legacy')
-rw-r--r--src/boost/libs/gil/test/legacy/CMakeLists.txt64
-rw-r--r--src/boost/libs/gil/test/legacy/Jamfile26
-rw-r--r--src/boost/libs/gil/test/legacy/README.md16
-rw-r--r--src/boost/libs/gil/test/legacy/channel.cpp408
-rw-r--r--src/boost/libs/gil/test/legacy/error_if.cpp13
-rw-r--r--src/boost/libs/gil/test/legacy/gil_reference_checksums.txt125
-rw-r--r--src/boost/libs/gil/test/legacy/image.cpp607
-rw-r--r--src/boost/libs/gil/test/legacy/performance.cpp516
-rw-r--r--src/boost/libs/gil/test/legacy/pixel.cpp322
-rw-r--r--src/boost/libs/gil/test/legacy/pixel_iterator.cpp355
-rw-r--r--src/boost/libs/gil/test/legacy/recreate_image.cpp105
-rw-r--r--src/boost/libs/gil/test/legacy/sample_image.cpp159
12 files changed, 2716 insertions, 0 deletions
diff --git a/src/boost/libs/gil/test/legacy/CMakeLists.txt b/src/boost/libs/gil/test/legacy/CMakeLists.txt
new file mode 100644
index 00000000..de870c96
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/CMakeLists.txt
@@ -0,0 +1,64 @@
+#
+# Copyright (c) 2019 Mateusz Loskot <mateusz at loskot dot net>
+#
+# Distributed under the Boost Software License, Version 1.0.
+# (See accompanying file LICENSE_1_0.txt or copy at
+# http://www.boost.org/LICENSE_1_0.txt)
+#
+# *** IMPORTANT MAINTENANCE RULES ***
+# These are GIL's original, comprehensive, all-in-one test suites.
+# * Keep as reference.
+# * Do NOT extend.
+# * Do NOT refactor.
+# * Modify only if absolutely necessary (a bug found in the tests).
+# See the accompanying README.md
+#
+message(STATUS "Boost.GIL: Configuring tests in test/legacy")
+
+foreach(_name
+ channel
+ pixel
+ pixel_iterator)
+ set(_test t_legacy_${_name})
+ set(_target test_legacy_${_name})
+
+ add_executable(${_target} "")
+ target_sources(${_target} PRIVATE ${_name}.cpp error_if.cpp)
+ target_link_libraries(${_target}
+ PRIVATE
+ gil_compile_options
+ gil_include_directories
+ gil_dependencies)
+ target_compile_definitions(${_target} PRIVATE BOOST_GIL_USE_CONCEPT_CHECK)
+ add_test(NAME ${_test} COMMAND ${_target})
+
+ unset(_name)
+ unset(_target)
+ unset(_test)
+endforeach()
+
+# Add extra source files accompanying image.cpp
+foreach(_name
+ image)
+ set(_test t_legacy_${_name})
+ set(_target test_legacy_${_name})
+
+ add_executable(${_target} "")
+ target_sources(${_target} PRIVATE
+ ${_name}.cpp
+ error_if.cpp
+ sample_image.cpp)
+
+ target_link_libraries(${_target}
+ PRIVATE
+ gil_compile_options
+ gil_include_directories
+ gil_dependencies)
+ target_compile_definitions(${_target} PRIVATE BOOST_GIL_USE_CONCEPT_CHECK)
+ add_test(NAME ${_test} COMMAND ${_target}
+ ${CMAKE_CURRENT_SOURCE_DIR}/gil_reference_checksums.txt)
+
+ unset(_name)
+ unset(_target)
+ unset(_test)
+endforeach()
diff --git a/src/boost/libs/gil/test/legacy/Jamfile b/src/boost/libs/gil/test/legacy/Jamfile
new file mode 100644
index 00000000..048ab8c4
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/Jamfile
@@ -0,0 +1,26 @@
+# Boost.GIL (Generic Image Library) - legacy tests
+#
+# Copyright (c) 2007-2015 Andrey Semashev
+# Copyright (c) 2008 Lubomir Bourdev, Hailin Jin
+#
+# Distributed under the Boost Software License, Version 1.0.
+# (See accompanying file LICENSE_1_0.txt or
+# copy at http://www.boost.org/LICENSE_1_0.txt)
+#
+# *** IMPORTANT MAINTENANCE RULES ***
+# These are GIL's original, comprehensive, all-in-one test suites.
+# * Keep as reference.
+# * Do NOT extend.
+# * Do NOT refactor.
+# * Modify only if absolutely necessary (a bug found in the tests).
+# See the accompanying README.md
+
+import testing ;
+
+run image.cpp sample_image.cpp error_if.cpp : : gil_reference_checksums.txt ;
+run channel.cpp error_if.cpp ;
+run pixel.cpp error_if.cpp ;
+run pixel_iterator.cpp error_if.cpp ;
+
+alias perf : [ run performance.cpp ] ;
+explicit perf ;
diff --git a/src/boost/libs/gil/test/legacy/README.md b/src/boost/libs/gil/test/legacy/README.md
new file mode 100644
index 00000000..76bc4282
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/README.md
@@ -0,0 +1,16 @@
+# Boost.GIL Legacy Tests
+
+These are GIL's original, comprehensive, all-in-one test suits.
+
+Rules of maintenance:
+
+* Run the legacy tests as part of CI builds and regression tests.
+* Keep as reference.
+* Do NOT extend.
+* Do NOT refactor.
+* Modify ONLY if absolutely necessary (a bug found in the tests).
+
+Add new test suites, with new test cases, even if their
+functional coverage is the same as of the legacy tests.
+
+See [CONTRIBUTING.md](../../CONTRIBUTING.md).
diff --git a/src/boost/libs/gil/test/legacy/channel.cpp b/src/boost/libs/gil/test/legacy/channel.cpp
new file mode 100644
index 00000000..b4225d20
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/channel.cpp
@@ -0,0 +1,408 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#include <boost/gil/channel.hpp>
+#include <boost/gil/channel_algorithm.hpp>
+#include <boost/gil/typedefs.hpp>
+
+#include <cstdint>
+#include <exception>
+#include <iostream>
+#include <type_traits>
+
+#if defined(BOOST_CLANG)
+#pragma clang diagnostic push
+#pragma clang diagnostic ignored "-Wfloat-equal"
+#elif BOOST_GCC >= 40700
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wfloat-equal"
+#elif BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
+#pragma warning(push)
+#pragma warning(disable:4512) //assignment operator could not be generated
+#endif
+
+using namespace boost::gil;
+using namespace std;
+
+void error_if(bool);
+
+auto c8_min = channel_traits<uint8_t>::min_value();
+auto c8_max = channel_traits<uint8_t>::max_value();
+auto c8s_min = channel_traits<int8_t>::min_value();
+auto c8s_max = channel_traits<int8_t>::max_value();
+auto c16_min = channel_traits<uint16_t>::min_value();
+auto c16_max = channel_traits<uint16_t>::max_value();
+auto c16s_min = channel_traits<int16_t>::min_value();
+auto c16s_max = channel_traits<int16_t>::max_value();
+auto c32_min = channel_traits<uint32_t>::min_value();
+auto c32_max = channel_traits<uint32_t>::max_value();
+auto c32s_min = channel_traits<int32_t>::min_value();
+auto c32s_max = channel_traits<int32_t>::max_value();
+auto c32f_min = channel_traits<float32_t>::min_value();
+auto c32f_max = channel_traits<float32_t>::max_value();
+
+
+template <typename ChannelTestCore>
+struct do_test : public ChannelTestCore {
+ using channel_t = typename ChannelTestCore::channel_t;
+ using channel_value_t = typename channel_traits<channel_t>::value_type;
+
+ do_test() : ChannelTestCore() {
+ error_if(this->_min_v != channel_traits<channel_t>::min_value());
+ error_if(this->_max_v != channel_traits<channel_t>::max_value());
+ }
+
+ void test_all() {
+ test_channel_invert();
+ test_channel_convert();
+ test_channel_multiply();
+ test_channel_math();
+ }
+
+ void test_mutable(std::false_type) {}
+ void test_mutable(std::true_type) {
+ channel_value_t mv=this->_min_v;
+ ++this->_min_v; this->_min_v++;
+ --this->_min_v; this->_min_v--;
+ error_if(mv!=this->_min_v);
+
+ this->_min_v+=1;
+ this->_min_v-=1;
+ error_if(mv!=this->_min_v);
+
+ this->_min_v*=1;
+ this->_min_v/=1;
+ error_if(mv!=this->_min_v);
+
+ this->_min_v = 1; // assignable to scalar
+ this->_min_v = mv; // and to value type
+
+ // test swap
+ channel_value_t v1=this->_min_v;
+ channel_value_t v2=this->_max_v;
+ swap(this->_min_v, this->_max_v);
+
+ channel_value_t v3=this->_min_v;
+ channel_value_t v4=this->_max_v;
+ error_if(v1!=v4 || v2!=v3);
+ }
+
+ void test_channel_math() {
+ error_if(this->_min_v >= this->_max_v);
+ error_if(this->_max_v <= this->_min_v);
+ error_if(this->_min_v > this->_max_v);
+ error_if(this->_max_v < this->_min_v);
+ error_if(this->_max_v == this->_min_v);
+ error_if(!(this->_max_v != this->_min_v));
+
+ error_if(this->_min_v * 1 != this->_min_v);
+ error_if(this->_min_v / 1 != this->_min_v);
+
+ error_if((this->_min_v + 1) + 1 != (this->_min_v + 2));
+ error_if((this->_max_v - 1) - 1 != (this->_max_v - 2));
+
+ error_if(this->_min_v != 1 && this->_min_v==1); // comparable to integral
+
+
+ test_mutable(std::integral_constant<bool, channel_traits<channel_t>::is_mutable>());
+ }
+
+
+ void test_channel_invert() {
+ error_if(channel_invert(this->_min_v) != this->_max_v);
+ error_if(channel_invert(this->_max_v) != this->_min_v);
+ }
+
+ void test_channel_multiply() {
+ error_if(channel_multiply(this->_min_v, this->_min_v) != this->_min_v);
+ error_if(channel_multiply(this->_max_v, this->_max_v) != this->_max_v);
+ error_if(channel_multiply(this->_max_v, this->_min_v) != this->_min_v);
+ }
+
+ void test_channel_convert() {
+ channel_value_t v_min, v_max;
+
+ v_min=channel_convert<channel_t>(c8_min);
+ v_max=channel_convert<channel_t>(c8_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+
+ v_min=channel_convert<channel_t>(c8s_min);
+ v_max=channel_convert<channel_t>(c8s_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+
+ v_min=channel_convert<channel_t>(c16_min);
+ v_max=channel_convert<channel_t>(c16_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+
+ v_min=channel_convert<channel_t>(c16s_min);
+ v_max=channel_convert<channel_t>(c16s_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+
+ v_min=channel_convert<channel_t>(c32_min);
+ v_max=channel_convert<channel_t>(c32_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+
+ v_min=channel_convert<channel_t>(c32s_min);
+ v_max=channel_convert<channel_t>(c32s_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+
+ v_min=channel_convert<channel_t>(c32f_min);
+ v_max=channel_convert<channel_t>(c32f_max);
+ error_if(v_min!=this->_min_v || v_max!=this->_max_v);
+ }
+};
+
+// Different core classes depending on the different types of channels - channel values, references and subbyte references
+// The cores ensure there are two members, _min_v and _max_v initialized with the minimum and maximum channel value.
+// The different channel types have different ways to initialize them, thus require different cores
+
+// For channel values simply initialize the value directly
+template <typename ChannelValue>
+class value_core {
+protected:
+ using channel_t = ChannelValue;
+ channel_t _min_v;
+ channel_t _max_v;
+
+ value_core()
+ : _min_v(channel_traits<ChannelValue>::min_value())
+ , _max_v(channel_traits<ChannelValue>::max_value())
+ {
+ boost::function_requires<ChannelValueConcept<ChannelValue> >();
+ }
+};
+
+// For channel references we need to have separate channel values
+template <typename ChannelRef>
+class reference_core : public value_core<typename channel_traits<ChannelRef>::value_type>
+{
+ using parent_t = value_core<typename channel_traits<ChannelRef>::value_type>;
+
+protected:
+ using channel_t = ChannelRef;
+ channel_t _min_v;
+ channel_t _max_v;
+
+ reference_core()
+ : parent_t()
+ , _min_v(parent_t::_min_v)
+ , _max_v(parent_t::_max_v)
+ {
+ boost::function_requires<ChannelConcept<ChannelRef> >();
+ }
+};
+
+// For subbyte channel references we need to store the bit buffers somewhere
+template <typename ChannelSubbyteRef, typename ChannelMutableRef = ChannelSubbyteRef>
+class packed_reference_core {
+protected:
+ using channel_t = ChannelSubbyteRef;
+ using integer_t = typename channel_t::integer_t;
+ channel_t _min_v, _max_v;
+
+ integer_t _min_buf, _max_buf;
+
+ packed_reference_core() : _min_v(&_min_buf), _max_v(&_max_buf) {
+ ChannelMutableRef b1(&_min_buf), b2(&_max_buf);
+ b1 = channel_traits<channel_t>::min_value();
+ b2 = channel_traits<channel_t>::max_value();
+
+ boost::function_requires<ChannelConcept<ChannelSubbyteRef> >();
+ }
+};
+
+template <typename ChannelSubbyteRef, typename ChannelMutableRef = ChannelSubbyteRef>
+class packed_dynamic_reference_core {
+protected:
+ using channel_t = ChannelSubbyteRef;
+ channel_t _min_v, _max_v;
+
+ typename channel_t::integer_t _min_buf, _max_buf;
+
+ packed_dynamic_reference_core(int first_bit1=1, int first_bit2=2) : _min_v(&_min_buf,first_bit1), _max_v(&_max_buf,first_bit2) {
+ ChannelMutableRef b1(&_min_buf,1), b2(&_max_buf,2);
+ b1 = channel_traits<channel_t>::min_value();
+ b2 = channel_traits<channel_t>::max_value();
+
+ boost::function_requires<ChannelConcept<ChannelSubbyteRef> >();
+ }
+};
+
+
+template <typename ChannelValue>
+void test_channel_value() {
+ do_test<value_core<ChannelValue> >().test_all();
+}
+
+template <typename ChannelRef>
+void test_channel_reference() {
+ do_test<reference_core<ChannelRef> >().test_all();
+}
+
+template <typename ChannelSubbyteRef>
+void test_packed_channel_reference() {
+ do_test<packed_reference_core<ChannelSubbyteRef,ChannelSubbyteRef> >().test_all();
+}
+
+template <typename ChannelSubbyteRef, typename MutableRef>
+void test_const_packed_channel_reference() {
+ do_test<packed_reference_core<ChannelSubbyteRef,MutableRef> >().test_all();
+}
+
+template <typename ChannelSubbyteRef>
+void test_packed_dynamic_channel_reference() {
+ do_test<packed_dynamic_reference_core<ChannelSubbyteRef,ChannelSubbyteRef> >().test_all();
+}
+
+template <typename ChannelSubbyteRef, typename MutableRef>
+void test_const_packed_dynamic_channel_reference() {
+ do_test<packed_dynamic_reference_core<ChannelSubbyteRef,MutableRef> >().test_all();
+}
+
+template <typename ChannelValue>
+void test_channel_value_impl() {
+ test_channel_value<ChannelValue>();
+ test_channel_reference<ChannelValue&>();
+ test_channel_reference<const ChannelValue&>();
+}
+
+/////////////////////////////////////////////////////////
+///
+/// A channel archetype - to test the minimum requirements of the concept
+///
+/////////////////////////////////////////////////////////
+
+struct channel_value_archetype;
+struct channel_archetype {
+ // equality comparable
+ friend bool operator==(const channel_archetype&,const channel_archetype&) { return true; }
+ friend bool operator!=(const channel_archetype&,const channel_archetype&) { return false; }
+ // less-than comparable
+ friend bool operator<(const channel_archetype&,const channel_archetype&) { return false; }
+ // convertible to a scalar
+ operator std::uint8_t() const { return 0; }
+
+
+ channel_archetype& operator++() { return *this; }
+ channel_archetype& operator--() { return *this; }
+ channel_archetype operator++(int) { return *this; }
+ channel_archetype operator--(int) { return *this; }
+
+ template <typename Scalar> channel_archetype operator+=(Scalar) { return *this; }
+ template <typename Scalar> channel_archetype operator-=(Scalar) { return *this; }
+ template <typename Scalar> channel_archetype operator*=(Scalar) { return *this; }
+ template <typename Scalar> channel_archetype operator/=(Scalar) { return *this; }
+
+ using value_type = channel_value_archetype;
+ using reference = channel_archetype;
+ using const_reference = channel_archetype const;
+ using pointer = channel_value_archetype *;
+ using const_pointer = channel_value_archetype const*;
+ static constexpr bool is_mutable=true;
+
+ static value_type min_value();
+ static value_type max_value();
+};
+
+
+struct channel_value_archetype : public channel_archetype {
+ channel_value_archetype() {} // default constructible
+ channel_value_archetype(const channel_value_archetype&) {} // copy constructible
+ channel_value_archetype& operator=(const channel_value_archetype&){return *this;} // assignable
+ channel_value_archetype(std::uint8_t) {}
+};
+
+channel_value_archetype channel_archetype::min_value() { return channel_value_archetype(); }
+channel_value_archetype channel_archetype::max_value() { return channel_value_archetype(); }
+
+
+void test_packed_channel_reference()
+{
+ using channel16_0_5_reference_t = packed_channel_reference<std::uint16_t, 0, 5, true>;
+ using channel16_5_6_reference_t = packed_channel_reference<std::uint16_t, 5, 6, true>;
+ using channel16_11_5_reference_t = packed_channel_reference<std::uint16_t, 11, 5, true>;
+
+ std::uint16_t data=0;
+ channel16_0_5_reference_t channel1(&data);
+ channel16_5_6_reference_t channel2(&data);
+ channel16_11_5_reference_t channel3(&data);
+
+ channel1=channel_traits<channel16_0_5_reference_t>::max_value();
+ channel2=channel_traits<channel16_5_6_reference_t>::max_value();
+ channel3=channel_traits<channel16_11_5_reference_t>::max_value();
+ error_if(data!=65535);
+
+ test_packed_channel_reference<channel16_0_5_reference_t>();
+ test_packed_channel_reference<channel16_5_6_reference_t>();
+ test_packed_channel_reference<channel16_11_5_reference_t>();
+}
+
+void test_packed_dynamic_channel_reference()
+{
+ using channel16_5_reference_t = packed_dynamic_channel_reference<std::uint16_t, 5, true>;
+ using channel16_6_reference_t = packed_dynamic_channel_reference<std::uint16_t, 6, true>;
+
+ std::uint16_t data=0;
+ channel16_5_reference_t channel1(&data,0);
+ channel16_6_reference_t channel2(&data,5);
+ channel16_5_reference_t channel3(&data,11);
+
+ channel1=channel_traits<channel16_5_reference_t>::max_value();
+ channel2=channel_traits<channel16_6_reference_t>::max_value();
+ channel3=channel_traits<channel16_5_reference_t>::max_value();
+ error_if(data!=65535);
+
+ test_packed_dynamic_channel_reference<channel16_5_reference_t>();
+}
+
+void test_channel() {
+ test_channel_value_impl<uint8_t>();
+ test_channel_value_impl<int8_t>();
+ test_channel_value_impl<uint16_t>();
+ test_channel_value_impl<int16_t>();
+ test_channel_value_impl<uint32_t>();
+ test_channel_value_impl<int16_t>();
+
+ test_channel_value_impl<float32_t>();
+
+ test_packed_channel_reference();
+ test_packed_dynamic_channel_reference();
+
+ // Do only compile-time tests for the archetype (because asserts like val1<val2 fail)
+ boost::function_requires<MutableChannelConcept<channel_archetype> >();
+
+ do_test<value_core<channel_value_archetype> >();
+ do_test<reference_core<channel_archetype> >();
+ do_test<reference_core<const channel_archetype&> >();
+}
+
+int main()
+{
+ try
+ {
+ test_channel();
+
+ return EXIT_SUCCESS;
+ }
+ catch (std::exception const& e)
+ {
+ std::cerr << e.what() << std::endl;
+ return EXIT_FAILURE;
+ }
+ catch (...)
+ {
+ return EXIT_FAILURE;
+ }
+}
+
+// TODO:
+// - provide algorithm performance overloads for scoped channel and packed channels
+// - Update concepts and documentation
+// - What to do about pointer types?!
+// - Performance!!
+// - is channel_convert the same as native?
+// - is operator++ on float32_t the same as native? How about if operator++ is defined in scoped_channel to do _value++?
diff --git a/src/boost/libs/gil/test/legacy/error_if.cpp b/src/boost/libs/gil/test/legacy/error_if.cpp
new file mode 100644
index 00000000..532d9062
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/error_if.cpp
@@ -0,0 +1,13 @@
+// Copyright 2008 Lubomir Bourdev and Hailin Jin
+//
+// Distributed under the Boost Software License, Version 1.0.
+// (See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt)
+
+#include <exception>
+
+void error_if(bool condition) {
+ if (condition)
+ throw std::exception();
+}
+
diff --git a/src/boost/libs/gil/test/legacy/gil_reference_checksums.txt b/src/boost/libs/gil/test/legacy/gil_reference_checksums.txt
new file mode 100644
index 00000000..ca123231
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/gil_reference_checksums.txt
@@ -0,0 +1,125 @@
+bgr121_basic_red_x 7f6e24e7
+bgr121_basic_white_x e4aaa1d3
+bgr121_histogram_histogram ca580192
+bgr121_views_0th_k_channel daa9f7e3
+bgr121_views_90ccw c64d6d20
+bgr121_views_90cw 8565efd8
+bgr121_views_cropped 43305e15
+bgr121_views_flipped_lr 2d68e448
+bgr121_views_flipped_ud 8f7f7d00
+bgr121_views_gray8 bbabe219
+bgr121_views_my_gray8 3086d22f
+bgr121_views_original 7e5bb87d
+bgr121_views_rot180 68f37202
+bgr121_views_subsampled ac6ca178
+bgr121_views_transpose da2ff80
+bgr8_basic_red_x 7f6e24e7
+bgr8_basic_white_x e4aaa1d3
+bgr8_histogram_histogram badcdd58
+bgr8_views_0th_k_channel 4638e58d
+bgr8_views_0th_n_channel 4638e58d
+bgr8_views_90ccw 8c4980e5
+bgr8_views_90cw e4c69665
+bgr8_views_cropped ff56b05e
+bgr8_views_flipped_lr 63849267
+bgr8_views_flipped_ud c4dcc848
+bgr8_views_gray8 3817178f
+bgr8_views_my_gray8 b33a27b9
+bgr8_views_original 423f1dde
+bgr8_views_rot180 150f1206
+bgr8_views_subsampled 92439ee7
+bgr8_views_transpose c9a890a0
+color_converted_0th_k_channel 3817178f
+color_converted_0th_n_channel 3817178f
+color_converted_90ccw dc403b3
+color_converted_90cw c6fc34de
+color_converted_cropped 666252a
+color_converted_flipped_lr 7ab2d721
+color_converted_flipped_ud 8ad49b3
+color_converted_gray8 3817178f
+color_converted_my_gray8 3817178f
+color_converted_original 3817178f
+color_converted_rot180 b5d0763b
+color_converted_subsampled 28286169
+color_converted_transpose 366b8392
+dynamic_ 423f1dde
+dynamic_fliplr 63849267
+dynamic_flipud c4dcc848
+dynamic_subimage a974d099
+dynamic_subimage_subsampled180rot 4055263a
+gray8_basic_red_x ab461c6a
+gray8_basic_white_x be81c274
+gray8_histogram_histogram badcdd58
+gray8_views_0th_k_channel 3817178f
+gray8_views_0th_n_channel 3817178f
+gray8_views_90ccw dc403b3
+gray8_views_90cw c6fc34de
+gray8_views_cropped 666252a
+gray8_views_flipped_lr 7ab2d721
+gray8_views_flipped_ud 8ad49b3
+gray8_views_gray8 3817178f
+gray8_views_my_gray8 3817178f
+gray8_views_original 3817178f
+gray8_views_rot180 b5d0763b
+gray8_views_subsampled 28286169
+gray8_views_transpose 366b8392
+mandelLuminosityGradient 4ebf3906
+planarrgb8_basic_red_x 7f6e24e7
+planarrgb8_basic_white_x e4aaa1d3
+planarrgb8_histogram_histogram badcdd58
+planarrgb8_views_0th_k_channel 1f48996f
+planarrgb8_views_0th_n_channel 1f48996f
+planarrgb8_views_90ccw 8c4980e5
+planarrgb8_views_90cw e4c69665
+planarrgb8_views_cropped ff56b05e
+planarrgb8_views_flipped_lr 63849267
+planarrgb8_views_flipped_ud c4dcc848
+planarrgb8_views_gray8 3817178f
+planarrgb8_views_my_gray8 b33a27b9
+planarrgb8_views_original 423f1dde
+planarrgb8_views_rot180 150f1206
+planarrgb8_views_subsampled 92439ee7
+planarrgb8_views_transpose c9a890a0
+rgb8_basic_red_x 7f6e24e7
+rgb8_basic_white_x e4aaa1d3
+rgb8_histogram_histogram badcdd58
+rgb8_views_0th_k_channel 1f48996f
+rgb8_views_0th_n_channel 1f48996f
+rgb8_views_90ccw 8c4980e5
+rgb8_views_90cw e4c69665
+rgb8_views_cropped ff56b05e
+rgb8_views_flipped_lr 63849267
+rgb8_views_flipped_ud c4dcc848
+rgb8_views_gray8 3817178f
+rgb8_views_my_gray8 b33a27b9
+rgb8_views_original 423f1dde
+rgb8_views_rot180 150f1206
+rgb8_views_subsampled 92439ee7
+rgb8_views_transpose c9a890a0
+subsampled_0th_k_channel 2c19afc1
+subsampled_0th_n_channel 2c19afc1
+subsampled_90ccw d4649279
+subsampled_90cw e74f0f0e
+subsampled_cropped a5f07581
+subsampled_flipped_lr 8f22df7
+subsampled_flipped_ud 26383f1d
+subsampled_gray8 c95e3def
+subsampled_my_gray8 91ea1379
+subsampled_original 64cf9a6b
+subsampled_rot180 6059029b
+subsampled_subsampled 59aef23b
+subsampled_transpose ec4b368a
+virtual_0th_k_channel 79bca658
+virtual_0th_n_channel 79bca658
+virtual_90ccw 965db1f7
+virtual_90cw a81d80e3
+virtual_cropped ffb4af2c
+virtual_flipped_lr 9d1478c2
+virtual_flipped_ud 18dc9b78
+virtual_gray8 962f6f6f
+virtual_histogram 8deb06eb
+virtual_my_gray8 150bb50d
+virtual_original 927686d4
+virtual_rot180 4dee193e
+virtual_subsampled e99b8073
+virtual_transpose 923e345f
diff --git a/src/boost/libs/gil/test/legacy/image.cpp b/src/boost/libs/gil/test/legacy/image.cpp
new file mode 100644
index 00000000..de75727c
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/image.cpp
@@ -0,0 +1,607 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#ifdef _MSC_VER
+#pragma warning(disable : 4244) // conversion from 'gil::image<V,Alloc>::coord_t' to 'int', possible loss of data (visual studio compiler doesn't realize that the two types are the same)
+#pragma warning(disable : 4503) // decorated name length exceeded, name was truncated
+#pragma warning(disable : 4701) // potentially uninitialized local variable 'result' used in boost/crc.hpp
+#endif
+
+#include <boost/gil.hpp>
+#include <boost/gil/extension/dynamic_image/dynamic_image_all.hpp>
+
+#include <boost/core/ignore_unused.hpp>
+#include <boost/crc.hpp>
+#include <boost/mp11.hpp>
+
+#include <ios>
+#include <iostream>
+#include <fstream>
+#include <map>
+#include <stdexcept>
+#include <string>
+#include <type_traits>
+#include <vector>
+
+using namespace boost::gil;
+using namespace std;
+using namespace boost;
+
+extern rgb8c_planar_view_t sample_view;
+void error_if(bool condition);
+
+#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
+#pragma warning(push)
+#pragma warning(disable:4127) //conditional expression is constant
+#endif
+
+// When BOOST_GIL_GENERATE_REFERENCE_DATA is defined, the reference data is generated and saved.
+// When it is undefined, regression tests are checked against it
+//#define BOOST_GIL_GENERATE_REFERENCE_DATA
+
+////////////////////////////////////////////////////
+///
+/// Some algorithms to use in testing
+///
+////////////////////////////////////////////////////
+
+template <typename GrayView, typename R>
+void gray_image_hist(GrayView const& img_view, R& hist)
+{
+ for (auto it = img_view.begin(); it != img_view.end(); ++it)
+ ++hist[*it];
+
+ // Alternatively, prefer the algorithm with lambda
+ // for_each_pixel(img_view, [&hist](gray8_pixel_t const& pixel) {
+ // ++hist[pixel];
+ // });
+}
+
+template <typename V, typename R>
+void get_hist(const V& img_view, R& hist) {
+ gray_image_hist(color_converted_view<gray8_pixel_t>(img_view), hist);
+}
+
+// testing custom color conversion
+template <typename C1, typename C2>
+struct my_color_converter_impl : public default_color_converter_impl<C1,C2> {};
+template <typename C1>
+struct my_color_converter_impl<C1,gray_t> {
+ template <typename P1, typename P2>
+ void operator()(const P1& src, P2& dst) const {
+ default_color_converter_impl<C1,gray_t>()(src,dst);
+ get_color(dst,gray_color_t())=channel_invert(get_color(dst,gray_color_t()));
+ }
+};
+
+struct my_color_converter {
+ template <typename SrcP,typename DstP>
+ void operator()(const SrcP& src,DstP& dst) const {
+ using src_cs_t = typename color_space_type<SrcP>::type;
+ using dst_cs_t = typename color_space_type<DstP>::type;
+ my_color_converter_impl<src_cs_t,dst_cs_t>()(src,dst);
+ }
+};
+
+/// Models a Unary Function
+/// \tparam P models PixelValueConcept
+template <typename P>
+struct mandelbrot_fn
+{
+ using point_t = boost::gil::point_t;
+ using const_t = mandelbrot_fn<P>;
+ using value_type = P;
+ using reference = value_type;
+ using const_reference = value_type;
+ using argument_type = point_t;
+ using result_type = reference;
+ static constexpr bool is_mutable = false;
+
+ value_type _in_color,_out_color;
+ point_t _img_size;
+ static const int MAX_ITER=100; // max number of iterations
+
+ mandelbrot_fn() {}
+ mandelbrot_fn(const point_t& sz, const value_type& in_color, const value_type& out_color) : _in_color(in_color), _out_color(out_color), _img_size(sz) {}
+
+ result_type operator()(const point_t& p) const {
+ // normalize the coords to (-2..1, -1.5..1.5)
+ // (actually make y -1.0..2 so it is asymmetric, so we can verify some view factory methods)
+ double t=get_num_iter(point<double>(p.x/(double)_img_size.x*3-2, p.y/(double)_img_size.y*3-1.0f));//1.5f));
+ t=pow(t,0.2);
+
+ value_type ret;
+ for (int k=0; k<num_channels<P>::value; ++k)
+ ret[k]=(typename channel_type<value_type>::type)(_in_color[k]*t + _out_color[k]*(1-t));
+ return ret;
+ }
+
+private:
+ double get_num_iter(const point<double>& p) const {
+ point<double> Z(0,0);
+ for (int i=0; i<MAX_ITER; ++i) {
+ Z = point<double>(Z.x*Z.x - Z.y*Z.y + p.x, 2*Z.x*Z.y + p.y);
+ if (Z.x*Z.x + Z.y*Z.y > 4)
+ return i/(double)MAX_ITER;
+ }
+ return 0;
+ }
+};
+
+template <typename T>
+void x_gradient(const T& src, const gray8s_view_t& dst) {
+ for (int y=0; y<src.height(); ++y) {
+ typename T::x_iterator src_it = src.row_begin(y);
+ gray8s_view_t::x_iterator dst_it = dst.row_begin(y);
+
+ for (int x=1; x<src.width()-1; ++x)
+ dst_it[x] = (src_it[x+1] - src_it[x-1]) / 2;
+ }
+}
+
+// A quick test whether a view is homogeneous
+
+template <typename Pixel>
+struct pixel_is_homogeneous : public std::true_type {};
+
+template <typename P, typename C, typename L>
+struct pixel_is_homogeneous<packed_pixel<P,C,L> > : public std::false_type {};
+
+template <typename View>
+struct view_is_homogeneous : public pixel_is_homogeneous<typename View::value_type> {};
+
+////////////////////////////////////////////////////
+///
+/// Tests image view transformations and algorithms
+///
+////////////////////////////////////////////////////
+class image_test {
+public:
+ virtual void initialize() {}
+ virtual void finalize() {}
+ virtual ~image_test() {}
+
+ void run();
+protected:
+ virtual void check_view_impl(const rgb8c_view_t& view, const string& name)=0;
+ template <typename View>
+ void check_view(const View& img_view, const string& name) {
+ rgb8_image_t rgb_img(img_view.dimensions());
+ copy_and_convert_pixels(img_view,view(rgb_img));
+ check_view_impl(const_view(rgb_img), name);
+ }
+private:
+ template <typename Img> void basic_test(const string& prefix);
+ template <typename View> void view_transformations_test(const View& img_view, const string& prefix);
+ template <typename View> void homogeneous_view_transformations_test(const View& img_view, const string& prefix, std::true_type);
+ template <typename View> void homogeneous_view_transformations_test(const View& img_view, const string& prefix, std::false_type)
+ {
+ boost::ignore_unused(img_view);
+ boost::ignore_unused(prefix);
+ }
+ template <typename View> void histogram_test(const View& img_view, const string& prefix);
+ void virtual_view_test();
+ void packed_image_test();
+ void dynamic_image_test();
+ template <typename Img> void image_all_test(const string& prefix);
+};
+
+// testing image iterators, clone, fill, locators, color convert
+template <typename Img>
+void image_test::basic_test(const string& prefix) {
+ using View = typename Img::view_t;
+
+ // make a 20x20 image
+ Img img(typename View::point_t(20,20));
+ const View& img_view=view(img);
+
+ // fill it with red
+ rgb8_pixel_t red8(255,0,0), green8(0,255,0), blue8(0,0,255), white8(255,255,255);
+ typename View::value_type red,green,blue,white;
+ color_convert(red8,red);
+ default_color_converter()(red8,red);
+ red=color_convert_deref_fn<rgb8_ref_t,typename Img::view_t::value_type>()(red8);
+
+ color_convert(green8,green);
+ color_convert(blue8,blue);
+ color_convert(white8,white);
+ fill(img_view.begin(),img_view.end(),red);
+
+ color_convert(red8,img_view[0]);
+
+ // pointer to first pixel of second row
+ typename View::reference rt=img_view.at(0,0)[img_view.width()];
+ typename View::x_iterator ptr=&rt;
+ typename View::reference rt2=*(img_view.at(0,0)+img_view.width());
+ typename View::x_iterator ptr2=&rt2;
+ error_if(ptr!=ptr2);
+ error_if(img_view.x_at(0,0)+10!=10+img_view.x_at(0,0));
+
+ // draw a blue line along the diagonal
+ typename View::xy_locator loc=img_view.xy_at(0,img_view.height()-1);
+ for (int y=0; y<img_view.height(); ++y) {
+ *loc=blue;
+ ++loc.x();
+ loc.y()--;
+ }
+
+ // draw a green dotted line along the main diagonal with step of 3
+ loc=img_view.xy_at(img_view.width()-1,img_view.height()-1);
+ while (loc.x()>=img_view.x_at(0,0)) {
+ *loc=green;
+ loc-=typename View::point_t(3,3);
+ }
+
+ // Clone and make every red pixel white
+ Img imgWhite(img);
+ for (typename View::iterator it=view(imgWhite).end(); (it-1)!=view(imgWhite).begin(); --it) {
+ if (*(it-1)==red)
+ *(it-1)=white;
+ }
+
+ check_view(img_view,prefix+"red_x");
+ check_view(view(imgWhite),prefix+"white_x");
+}
+
+template <typename View>
+void image_test::histogram_test(const View& img_view, const string& prefix) {
+// vector<int> histogram(255,0);
+// get_hist(cropped,histogram.begin());
+ unsigned char histogram[256];
+ fill(histogram,histogram+256,0);
+ get_hist(img_view,histogram);
+ gray8c_view_t hist_view=interleaved_view(256,1,(const gray8_pixel_t*)histogram,256);
+ check_view(hist_view,prefix+"histogram");
+}
+
+template <typename View>
+void image_test::view_transformations_test(const View& img_view, const string& prefix) {
+ check_view(img_view,prefix+"original");
+
+ check_view(subimage_view(img_view, iround(img_view.dimensions()/4), iround(img_view.dimensions()/2)),prefix+"cropped");
+ check_view(color_converted_view<gray8_pixel_t>(img_view),prefix+"gray8");
+ check_view(color_converted_view<gray8_pixel_t>(img_view,my_color_converter()),prefix+"my_gray8");
+ check_view(transposed_view(img_view),prefix+"transpose");
+ check_view(rotated180_view(img_view),prefix+"rot180");
+ check_view(rotated90cw_view(img_view),prefix+"90cw");
+ check_view(rotated90ccw_view(img_view),prefix+"90ccw");
+ check_view(flipped_up_down_view(img_view),prefix+"flipped_ud");
+ check_view(flipped_left_right_view(img_view),prefix+"flipped_lr");
+ check_view(subsampled_view(img_view,typename View::point_t(2,1)),prefix+"subsampled");
+ check_view(kth_channel_view<0>(img_view),prefix+"0th_k_channel");
+ homogeneous_view_transformations_test(img_view, prefix, view_is_homogeneous<View>());
+}
+
+template <typename View>
+void image_test::homogeneous_view_transformations_test(const View& img_view, const string& prefix, std::true_type) {
+ check_view(nth_channel_view(img_view,0),prefix+"0th_n_channel");
+}
+
+void image_test::virtual_view_test()
+{
+ using deref_t = mandelbrot_fn<rgb8_pixel_t>;
+ using point_t = deref_t::point_t;
+ using locator_t = virtual_2d_locator<deref_t, false>;
+ using my_virt_view_t = image_view<locator_t>;
+
+ boost::function_requires<PixelLocatorConcept<locator_t> >();
+ gil_function_requires<StepIteratorConcept<locator_t::x_iterator> >();
+
+ point_t dims(200,200);
+ my_virt_view_t mandel(dims, locator_t(point_t(0,0), point_t(1,1), deref_t(dims, rgb8_pixel_t(255,0,255), rgb8_pixel_t(0,255,0))));
+
+ gray8s_image_t img(dims);
+ fill_pixels(view(img),0); // our x_gradient algorithm doesn't change the first & last column, so make sure they are 0
+ x_gradient(color_converted_view<gray8_pixel_t>(mandel), view(img));
+ check_view(color_converted_view<gray8_pixel_t>(const_view(img)), "mandelLuminosityGradient");
+
+ view_transformations_test(mandel,"virtual_");
+ histogram_test(mandel,"virtual_");
+}
+
+// Test alignment and packed images
+void image_test::packed_image_test()
+{
+ using bgr131_image_t = bit_aligned_image3_type<1,3,1, bgr_layout_t>::type;
+ using bgr131_pixel_t = bgr131_image_t::value_type;
+ bgr131_pixel_t fill_val(1,3,1);
+
+ bgr131_image_t bgr131_img(3,10);
+ fill_pixels(view(bgr131_img), fill_val);
+
+ bgr131_image_t bgr131a_img(3,10,1);
+ copy_pixels(const_view(bgr131_img), view(bgr131a_img));
+
+ bgr131_image_t bgr131b_img(3,10,4);
+ copy_pixels(const_view(bgr131_img), view(bgr131b_img));
+
+ error_if(bgr131_img!=bgr131a_img || bgr131a_img!=bgr131b_img);
+}
+
+void image_test::dynamic_image_test()
+{
+ using any_image_t = any_image
+ <
+ mp11::mp_list
+ <
+ gray8_image_t,
+ bgr8_image_t,
+ argb8_image_t,
+ rgb8_image_t,
+ rgb8_planar_image_t
+ >
+ >;
+ rgb8_planar_image_t img(sample_view.dimensions());
+ copy_pixels(sample_view, view(img));
+ any_image_t any_img=any_image_t(img);
+
+ check_view(view(any_img), "dynamic_");
+ check_view(flipped_left_right_view(view(any_img)), "dynamic_fliplr");
+ check_view(flipped_up_down_view(view(any_img)), "dynamic_flipud");
+
+ any_image_t::view_t subimageView=subimage_view(view(any_img),0,0,10,15);
+
+ check_view(subimageView, "dynamic_subimage");
+ check_view(subsampled_view(rotated180_view(view(any_img)), 2,1), "dynamic_subimage_subsampled180rot");
+}
+
+template <typename Img>
+void image_test::image_all_test(const string& prefix) {
+ basic_test<Img>(prefix+"basic_");
+
+ Img img;
+ img.recreate(sample_view.dimensions());
+ copy_and_convert_pixels(sample_view,view(img));
+
+ view_transformations_test(view(img), prefix+"views_");
+
+ histogram_test(const_view(img),prefix+"histogram_");
+}
+
+void image_test::run() {
+ initialize();
+
+ image_all_test<bgr8_image_t>("bgr8_");
+ image_all_test<rgb8_image_t>("rgb8_");
+ image_all_test<rgb8_planar_image_t>("planarrgb8_");
+ image_all_test<gray8_image_t>("gray8_");
+
+ using bgr121_ref_t = bit_aligned_pixel_reference
+ <
+ boost::uint8_t,
+ mp11::mp_list_c<int, 1, 2, 1>,
+ bgr_layout_t,
+ true
+ > const;
+ using bgr121_image_t = image<bgr121_ref_t, false>;
+ image_all_test<bgr121_image_t>("bgr121_");
+
+ // TODO: Remove?
+ view_transformations_test(subsampled_view(sample_view, point_t(1,2)), "subsampled_");
+ view_transformations_test(color_converted_view<gray8_pixel_t>(sample_view),"color_converted_");
+
+ virtual_view_test();
+ packed_image_test();
+ dynamic_image_test();
+
+ finalize();
+}
+
+////////////////////////////////////////////////////
+///
+/// Performs or generates image tests using checksums
+///
+////////////////////////////////////////////////////
+
+class checksum_image_mgr : public image_test
+{
+protected:
+ using crc_map_t = map<string, boost::crc_32_type::value_type>;
+ crc_map_t _crc_map;
+};
+
+////////////////////////////////////////////////////
+///
+/// Performs image tests by comparing image pixel checksums against a reference
+///
+////////////////////////////////////////////////////
+
+class checksum_image_test : public checksum_image_mgr {
+public:
+ checksum_image_test(const char* filename) : _filename(filename) {}
+private:
+ const char* _filename;
+ void initialize() override;
+ void check_view_impl(const rgb8c_view_t& v, const string& name) override;
+};
+
+// Load the checksums from the reference file and create the start image
+void checksum_image_test::initialize() {
+ boost::crc_32_type::value_type crc_result;
+ fstream checksum_ref(_filename,ios::in);
+ while (true) {
+ string crc_name;
+ checksum_ref >> crc_name >> std::hex >> crc_result;
+ if(checksum_ref.fail()) break;
+ if (!crc_name.empty() && crc_name[0] == '#')
+ {
+ crc_result = 0; // skip test case
+ crc_name = crc_name.substr(1);
+ }
+ _crc_map[crc_name]=crc_result;
+ }
+ checksum_ref.close();
+}
+
+// Create a checksum for the given view and compare it with the reference checksum. Throw exception if different
+void checksum_image_test::check_view_impl(const rgb8c_view_t& img_view, const string& name) {
+ boost::crc_32_type checksum_acumulator;
+ checksum_acumulator.process_bytes(img_view.row_begin(0),img_view.size()*3);
+ unsigned int const crc_expect = _crc_map[name];
+ if (crc_expect == 0)
+ {
+ cerr << "Skipping checksum check for " << name << " (crc=0)" << endl;
+ return;
+ }
+
+ boost::crc_32_type::value_type const crc = checksum_acumulator.checksum();
+ if (crc==crc_expect) {
+ cerr << "Checking checksum for " << name << " (crc=" << std::hex << crc << ")" << endl;
+ }
+ else {
+ cerr << "Checksum error in " << name
+ << " (crc=" << std::hex << crc << " != " << std::hex << crc_expect << ")" << endl;
+ error_if(true);
+ }
+}
+
+////////////////////////////////////////////////////
+///
+/// Generates a set of reference checksums to compare against
+///
+////////////////////////////////////////////////////
+
+class checksum_image_generate : public checksum_image_mgr {
+public:
+ checksum_image_generate(const char* filename) : _filename(filename) {}
+private:
+ const char* _filename;
+ void check_view_impl(const rgb8c_view_t& img_view, const string& name) override;
+ void finalize() override;
+};
+
+// Add the checksum of the given view to the map of checksums
+void checksum_image_generate::check_view_impl(const rgb8c_view_t& img_view, const string& name) {
+ boost::crc_32_type result;
+ result.process_bytes(img_view.row_begin(0),img_view.size()*3);
+ cerr << "Generating checksum for " << name << endl;
+ _crc_map[name] = result.checksum();
+}
+
+// Save the checksums into the reference file
+void checksum_image_generate::finalize() {
+ fstream checksum_ref(_filename,ios::out);
+ for (crc_map_t::const_iterator it=_crc_map.begin(); it!=_crc_map.end(); ++it) {
+ checksum_ref << it->first << " " << std::hex << it->second << "\r\n";
+ }
+ checksum_ref.close();
+}
+
+////////////////////////////////////////////////////
+///
+/// Performs or generates image tests using image I/O
+///
+////////////////////////////////////////////////////
+
+extern const string in_dir;
+extern const string out_dir;
+extern const string ref_dir;
+
+const string in_dir=""; // directory of source images
+const string out_dir=in_dir+"image-out/"; // directory where to write output
+const string ref_dir=in_dir+"image-ref/"; // reference directory to compare written with actual output
+
+void static_checks() {
+ gil_function_requires<ImageConcept<rgb8_image_t> >();
+
+ static_assert(view_is_basic<rgb8_step_view_t>::value, "");
+ static_assert(view_is_basic<cmyk8c_planar_step_view_t>::value, "");
+ static_assert(view_is_basic<rgb8_planar_view_t>::value, "");
+
+ static_assert(view_is_step_in_x<rgb8_step_view_t>::value, "");
+ static_assert(view_is_step_in_x<cmyk8c_planar_step_view_t>::value, "");
+ static_assert(!view_is_step_in_x<rgb8_planar_view_t>::value, "");
+
+ static_assert(!is_planar<rgb8_step_view_t>::value, "");
+ static_assert(is_planar<cmyk8c_planar_step_view_t>::value, "");
+ static_assert(is_planar<rgb8_planar_view_t>::value, "");
+
+ static_assert(view_is_mutable<rgb8_step_view_t>::value, "");
+ static_assert(!view_is_mutable<cmyk8c_planar_step_view_t>::value, "");
+ static_assert(view_is_mutable<rgb8_planar_view_t>::value, "");
+
+ static_assert(std::is_same
+ <
+ derived_view_type<cmyk8c_planar_step_view_t>::type,
+ cmyk8c_planar_step_view_t
+ >::value, "");
+ static_assert(std::is_same
+ <
+ derived_view_type
+ <
+ cmyk8c_planar_step_view_t, std::uint16_t, rgb_layout_t
+ >::type,
+ rgb16c_planar_step_view_t
+ >::value, "");
+ static_assert(std::is_same
+ <
+ derived_view_type
+ <
+ cmyk8c_planar_step_view_t, use_default, rgb_layout_t, std::false_type, use_default, std::false_type
+ >::type,
+ rgb8c_step_view_t
+ >::value, "");
+
+ // test view get raw data (mostly compile-time test)
+ {
+ rgb8_image_t rgb8(100,100);
+ unsigned char* data=interleaved_view_get_raw_data(view(rgb8));
+ const unsigned char* cdata=interleaved_view_get_raw_data(const_view(rgb8));
+ error_if(data!=cdata);
+ }
+
+ {
+ rgb16s_planar_image_t rgb8(100,100);
+ short* data=planar_view_get_raw_data(view(rgb8),1);
+ const short* cdata=planar_view_get_raw_data(const_view(rgb8),1);
+ error_if(data!=cdata);
+ }
+}
+
+using image_test_t = checksum_image_test;
+using image_generate_t = checksum_image_generate;
+
+#ifdef BOOST_GIL_GENERATE_REFERENCE_DATA
+using image_mgr_t = image_generate_t;
+#else
+using image_mgr_t = image_test_t;
+#endif
+
+void test_image(const char* ref_checksum) {
+ image_mgr_t mgr(ref_checksum);
+
+ cerr << "Reading checksums from " << ref_checksum << endl;
+ mgr.run();
+ static_checks();
+}
+
+int main(int argc, char* argv[])
+{
+ try
+ {
+ if (argc != 2)
+ throw std::runtime_error("No file with reference checksums specified");
+
+ std::string local_name = argv[1];
+ std::ifstream file_is_there(local_name.c_str());
+ if (!file_is_there)
+ throw std::runtime_error("Unable to open gil_reference_checksums.txt");
+
+ test_image(local_name.c_str());
+
+ return EXIT_SUCCESS;
+ }
+ catch (std::exception const& e)
+ {
+ std::cerr << e.what() << std::endl;
+ return EXIT_FAILURE;
+ }
+ catch (...)
+ {
+ return EXIT_FAILURE;
+ }
+}
diff --git a/src/boost/libs/gil/test/legacy/performance.cpp b/src/boost/libs/gil/test/legacy/performance.cpp
new file mode 100644
index 00000000..2d20d875
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/performance.cpp
@@ -0,0 +1,516 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#include <boost/gil.hpp>
+
+#include <boost/test/unit_test.hpp>
+
+#include <cstddef>
+#include <ctime>
+#include <iostream>
+
+// GIL performance test suite
+//
+// Available tests:
+// fill_pixels() on rgb8_image_t with rgb8_pixel_t
+// fill_pixels() on rgb8_planar_image_t with rgb8_pixel_t
+// fill_pixels() on rgb8_image_t with bgr8_pixel_t
+// fill_pixels() on rgb8_planar_image_t with bgr8_pixel_t
+// for_each_pixel() on rgb8_image_t
+// for_each_pixel() on rgb8_planar_t
+// copy_pixels() between rgb8_image_t and rgb8_image_t
+// copy_pixels() between rgb8_image_t and bgr8_image_t
+// copy_pixels() between rgb8_planar_image_t and rgb8_planar_image_t
+// copy_pixels() between rgb8_image_t and rgb8_planar_image_t
+// copy_pixels() between rgb8_planar_image_t and rgb8_image_t
+// transform_pixels() between rgb8_image_t and rgb8_image_t
+// transform_pixels() between rgb8_planar_image_t and rgb8_planar_image_t
+// transform_pixels() between rgb8_planar_image_t and rgb8_image_t
+// transform_pixels() between rgb8_image_t and rgb8_planar_image_t
+
+using namespace boost::gil;
+
+// returns time in milliseconds per call
+template <typename Op>
+double measure_time(Op op, std::size_t num_loops) {
+ clock_t begin=clock();
+ for (std::size_t ii=0; ii<num_loops; ++ii) op();
+ return double(clock()-begin)/double(num_loops);
+}
+
+// image dimension
+std::size_t width=1000, height=400;
+
+// macros for standard GIL views
+#define RGB_VIEW(T) image_view<memory_based_2d_locator<memory_based_step_iterator<pixel<T,rgb_layout_t>*>>>
+#define BGR_VIEW(T) image_view<memory_based_2d_locator<memory_based_step_iterator<pixel<T,bgr_layout_t>*>>>
+#define RGB_PLANAR_VIEW(T) image_view<memory_based_2d_locator<memory_based_step_iterator<planar_pixel_iterator<T*,rgb_t>>>>
+
+template <typename View, typename P>
+struct fill_gil_t {
+ View _v;
+ P _p;
+ fill_gil_t(const View& v_in,const P& p_in) : _v(v_in), _p(p_in) {}
+ void operator()() const {fill_pixels(_v,_p);}
+};
+template <typename View, typename P> struct fill_nongil_t;
+template <typename T, typename P>
+struct fill_nongil_t<RGB_VIEW(T), P>
+{
+ using View = RGB_VIEW(T);
+ View _v;
+ P _p;
+ fill_nongil_t(const View& v_in,const P& p_in) : _v(v_in), _p(p_in) {}
+ void operator()() const {
+ T* first=(T*)_v.row_begin(0);
+ T* last=first+_v.size()*3;
+ while(first!=last) {
+ first[0]=boost::gil::at_c<0>(_p);
+ first[1]=boost::gil::at_c<1>(_p);
+ first[2]=boost::gil::at_c<2>(_p);
+ first+=3;
+ }
+ }
+};
+template <typename T1, typename T2>
+struct fill_nongil_t<RGB_VIEW(T1), pixel<T2,bgr_layout_t>>
+{
+ using View = RGB_VIEW(T1);
+ using P = pixel<T2, bgr_layout_t>;
+ View _v;
+ P _p;
+ fill_nongil_t(const View& v_in,const P& p_in) : _v(v_in), _p(p_in) {}
+ void operator()() const {
+ T1* first=(T1*)_v.row_begin(0);
+ T1* last=first+_v.size()*3;
+ while(first!=last) {
+ first[0]=boost::gil::at_c<2>(_p);
+ first[1]=boost::gil::at_c<1>(_p);
+ first[2]=boost::gil::at_c<0>(_p);
+ first+=3;
+ }
+ }
+};
+template <typename T1, typename T2>
+struct fill_nongil_t<RGB_PLANAR_VIEW(T1), pixel<T2,rgb_layout_t>>
+{
+ using View = RGB_PLANAR_VIEW(T1);
+ using P = pixel<T2, rgb_layout_t>;
+ View _v;
+ P _p;
+ fill_nongil_t(const View& v_in,const P& p_in) : _v(v_in), _p(p_in) {}
+ void operator()() const {
+ std::size_t size=_v.size();
+ T1* first;
+ first=(T1*)boost::gil::at_c<0>(_v.row_begin(0));
+ std::fill(first,first+size,boost::gil::at_c<0>(_p));
+ first=(T1*)boost::gil::at_c<1>(_v.row_begin(0));
+ std::fill(first,first+size,boost::gil::at_c<1>(_p));
+ first=(T1*)boost::gil::at_c<2>(_v.row_begin(0));
+ std::fill(first,first+size,boost::gil::at_c<2>(_p));
+ }
+};
+
+template <typename T1, typename T2>
+struct fill_nongil_t<RGB_PLANAR_VIEW(T1), pixel<T2,bgr_layout_t>>
+{
+ using View = RGB_PLANAR_VIEW(T1);
+ using P = pixel<T2,bgr_layout_t>;
+ View _v;
+ P _p;
+ fill_nongil_t(const View& v_in,const P& p_in) : _v(v_in), _p(p_in) {}
+ void operator()() const {
+ std::size_t size=_v.size();
+ T1* first;
+ first=(T1*)boost::gil::at_c<0>(_v.row_begin(0));
+ std::fill(first,first+size,boost::gil::at_c<2>(_p));
+ first=(T1*)boost::gil::at_c<1>(_v.row_begin(0));
+ std::fill(first,first+size,boost::gil::at_c<1>(_p));
+ first=(T1*)boost::gil::at_c<2>(_v.row_begin(0));
+ std::fill(first,first+size,boost::gil::at_c<1>(_p));
+ }
+};
+
+template <typename View, typename P>
+void test_fill(std::size_t trials) {
+ image<typename View::value_type, is_planar<View>::value> im(width,height);
+ std::cout << "GIL: "<< measure_time(fill_gil_t<View,P>(view(im),P()),trials) << std::endl;
+ std::cout << "Non-GIL: "<< measure_time(fill_nongil_t<View,P>(view(im),P()),trials) << std::endl;
+};
+
+template <typename T>
+struct rgb_fr_t {
+ void operator()(pixel<T,rgb_layout_t>& p) const {p[0]=0;p[1]=1;p[2]=2;}
+ void operator()(const planar_pixel_reference<T&,rgb_t>& p) const {p[0]=0;p[1]=1;p[2]=2;}
+};
+template <typename View, typename F>
+struct for_each_gil_t {
+ View _v;
+ F _f;
+ for_each_gil_t(const View& v_in,const F& f_in) : _v(v_in), _f(f_in) {}
+ void operator()() const {for_each_pixel(_v,_f);}
+};
+template <typename View, typename F> struct for_each_nongil_t;
+template <typename T, typename T2>
+struct for_each_nongil_t<RGB_VIEW(T), rgb_fr_t<T2>>
+{
+ using View = RGB_VIEW(T);
+ using F = rgb_fr_t<T2>;
+ View _v;
+ F _f;
+ for_each_nongil_t(const View& v_in,const F& f_in) : _v(v_in), _f(f_in) {}
+ void operator()() const {
+ T* first=(T*)_v.row_begin(0);
+ T* last=first+_v.size()*3;
+ while(first!=last) {
+ first[0]=0;
+ first[1]=1;
+ first[2]=2;
+ first+=3;
+ }
+ }
+};
+template <typename T1, typename T2>
+struct for_each_nongil_t<RGB_PLANAR_VIEW(T1), rgb_fr_t<T2>>
+{
+ using View = RGB_PLANAR_VIEW(T1);
+ using F = rgb_fr_t<T2>;
+ View _v;
+ F _f;
+ for_each_nongil_t(const View& v_in,const F& f_in) : _v(v_in), _f(f_in) {}
+ void operator()() const {
+ T1 *first0, *first1, *first2, *last0;
+ first0=(T1*)boost::gil::at_c<0>(_v.row_begin(0));
+ first1=(T1*)boost::gil::at_c<1>(_v.row_begin(0));
+ first2=(T1*)boost::gil::at_c<2>(_v.row_begin(0));
+ last0=first0+_v.size();
+ while(first0!=last0) {
+ *first0++=0;
+ *first1++=1;
+ *first2++=2;
+ }
+ }
+};
+
+template <typename View, typename F>
+void test_for_each(std::size_t trials) {
+ image<typename View::value_type, is_planar<View>::value> im(width,height);
+ std::cout << "GIL: "<<measure_time(for_each_gil_t<View,F>(view(im),F()),trials) << std::endl;
+ std::cout << "Non-GIL: "<<measure_time(for_each_nongil_t<View,F>(view(im),F()),trials) << std::endl;
+}
+
+// copy
+template <typename View1, typename View2>
+struct copy_gil_t {
+ View1 _v1;
+ View2 _v2;
+ copy_gil_t(const View1& v1_in,const View2& v2_in) : _v1(v1_in), _v2(v2_in) {}
+ void operator()() const {copy_pixels(_v1,_v2);}
+};
+template <typename View1, typename View2> struct copy_nongil_t;
+template <typename T1, typename T2>
+struct copy_nongil_t<RGB_VIEW(T1),RGB_VIEW(T2)>
+{
+ using View1 = RGB_VIEW(T1);
+ using View2 = RGB_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ copy_nongil_t(const View1& v1_in,const View2& v2_in) : _v1(v1_in), _v2(v2_in) {}
+ void operator()() const {
+ T1* first1=(T1*)_v1.row_begin(0);
+ T1* last1=first1+_v1.size()*3;
+ T2* first2=(T2*)_v2.row_begin(0);
+ std::copy(first1,last1,first2);
+ }
+};
+template <typename T1, typename T2>
+struct copy_nongil_t<RGB_VIEW(T1),BGR_VIEW(T2)>
+{
+ using View1 = RGB_VIEW(T1);
+ using View2 = BGR_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ copy_nongil_t(const View1& v1_in,const View2& v2_in) : _v1(v1_in), _v2(v2_in) {}
+ void operator()() const {
+ T1* first1=(T1*)_v1.row_begin(0);
+ T1* last1=first1+_v1.size()*3;
+ T2* first2=(T2*)_v2.row_begin(0);
+ while(first1!=last1) {
+ first2[2]=first1[0];
+ first2[1]=first1[1];
+ first2[0]=first1[2];
+ first1+=3; first2+=3;
+ }
+ }
+};
+template <typename T1, typename T2>
+struct copy_nongil_t<RGB_PLANAR_VIEW(T1),RGB_PLANAR_VIEW(T2)>
+{
+ using View1 = RGB_PLANAR_VIEW(T1);
+ using View2 = RGB_PLANAR_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ copy_nongil_t(const View1& v1_in,const View2& v2_in) : _v1(v1_in), _v2(v2_in) {}
+ void operator()() const {
+ std::size_t size=_v1.size();
+ T1* first10=(T1*)boost::gil::at_c<0>(_v1.row_begin(0));
+ T1* first11=(T1*)boost::gil::at_c<1>(_v1.row_begin(0));
+ T1* first12=(T1*)boost::gil::at_c<2>(_v1.row_begin(0));
+ T2* first20=(T2*)boost::gil::at_c<0>(_v2.row_begin(0));
+ T2* first21=(T2*)boost::gil::at_c<1>(_v2.row_begin(0));
+ T2* first22=(T2*)boost::gil::at_c<2>(_v2.row_begin(0));
+ std::copy(first10,first10+size,first20);
+ std::copy(first11,first11+size,first21);
+ std::copy(first12,first12+size,first22);
+ }
+};
+template <typename T1, typename T2>
+struct copy_nongil_t<RGB_VIEW(T1),RGB_PLANAR_VIEW(T2)>
+{
+ using View1 = RGB_VIEW(T1);
+ using View2 = RGB_PLANAR_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ copy_nongil_t(const View1& v1_in,const View2& v2_in) : _v1(v1_in), _v2(v2_in) {}
+ void operator()() const {
+ T1* first=(T1*)_v1.row_begin(0);
+ T1* last=first+_v1.size()*3;
+ T2* first0=(T2*)boost::gil::at_c<0>(_v2.row_begin(0));
+ T2* first1=(T2*)boost::gil::at_c<1>(_v2.row_begin(0));
+ T2* first2=(T2*)boost::gil::at_c<2>(_v2.row_begin(0));
+ while(first!=last) {
+ *first0++=first[0];
+ *first1++=first[1];
+ *first2++=first[2];
+ first+=3;
+ }
+ }
+};
+template <typename T1, typename T2>
+struct copy_nongil_t<RGB_PLANAR_VIEW(T1),RGB_VIEW(T2)>
+{
+ using View1 = RGB_PLANAR_VIEW(T1);
+ using View2 = RGB_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ copy_nongil_t(const View1& v1_in,const View2& v2_in) : _v1(v1_in), _v2(v2_in) {}
+ void operator()() const {
+ T1* first=(T1*)_v2.row_begin(0);
+ T1* last=first+_v2.size()*3;
+ T2* first0=(T2*)boost::gil::at_c<0>(_v1.row_begin(0));
+ T2* first1=(T2*)boost::gil::at_c<1>(_v1.row_begin(0));
+ T2* first2=(T2*)boost::gil::at_c<2>(_v1.row_begin(0));
+ while(first!=last) {
+ first[0]=*first0++;
+ first[1]=*first1++;
+ first[2]=*first2++;
+ first+=3;
+ }
+ }
+};
+template <typename View1, typename View2>
+void test_copy(std::size_t trials) {
+ image<typename View1::value_type, is_planar<View1>::value> im1(width,height);
+ image<typename View2::value_type, is_planar<View2>::value> im2(width,height);
+ std::cout << "GIL: " <<measure_time(copy_gil_t<View1,View2>(view(im1),view(im2)),trials) << std::endl;
+ std::cout << "Non-GIL: "<<measure_time(copy_nongil_t<View1,View2>(view(im1),view(im2)),trials) << std::endl;
+}
+
+// transform()
+template <typename T,typename Pixel>
+struct bgr_to_rgb_t {
+ pixel<T,rgb_layout_t> operator()(const Pixel& p) const {
+ return pixel<T,rgb_layout_t>(T(get_color(p,blue_t())*0.1f),
+ T(get_color(p,green_t())*0.2f),
+ T(get_color(p,red_t())*0.3f));
+ }
+};
+template <typename View1, typename View2, typename F>
+struct transform_gil_t {
+ View1 _v1;
+ View2 _v2;
+ F _f;
+ transform_gil_t(const View1& v1_in,const View2& v2_in,const F& f_in) : _v1(v1_in),_v2(v2_in),_f(f_in) {}
+ void operator()() const {transform_pixels(_v1,_v2,_f);}
+};
+template <typename View1, typename View2, typename F> struct transform_nongil_t;
+template <typename T1, typename T2, typename F>
+struct transform_nongil_t<RGB_VIEW(T1),RGB_VIEW(T2),F>
+{
+ using View1 = RGB_VIEW(T1);
+ using View2 = RGB_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ F _f;
+ transform_nongil_t(const View1& v1_in,const View2& v2_in,const F& f_in) : _v1(v1_in),_v2(v2_in),_f(f_in) {}
+ void operator()() const {
+ T1* first1=(T1*)_v1.row_begin(0);
+ T2* first2=(T1*)_v2.row_begin(0);
+ T1* last1=first1+_v1.size()*3;
+ while(first1!=last1) {
+ first2[0]=T2(first1[2]*0.1f);
+ first2[1]=T2(first1[1]*0.2f);
+ first2[2]=T2(first1[0]*0.3f);
+ first1+=3; first2+=3;
+ }
+ }
+};
+template <typename T1, typename T2, typename F>
+struct transform_nongil_t<RGB_PLANAR_VIEW(T1),RGB_PLANAR_VIEW(T2),F>
+{
+ using View1 = RGB_PLANAR_VIEW(T1);
+ using View2 = RGB_PLANAR_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ F _f;
+ transform_nongil_t(const View1& v1_in,const View2& v2_in,const F& f_in) : _v1(v1_in),_v2(v2_in),_f(f_in) {}
+ void operator()() const {
+ T1* first10=(T1*)boost::gil::at_c<0>(_v1.row_begin(0));
+ T1* first11=(T1*)boost::gil::at_c<1>(_v1.row_begin(0));
+ T1* first12=(T1*)boost::gil::at_c<2>(_v1.row_begin(0));
+ T1* first20=(T2*)boost::gil::at_c<0>(_v2.row_begin(0));
+ T1* first21=(T2*)boost::gil::at_c<1>(_v2.row_begin(0));
+ T1* first22=(T2*)boost::gil::at_c<2>(_v2.row_begin(0));
+ T1* last10=first10+_v1.size();
+ while(first10!=last10) {
+ *first20++=T2(*first12++*0.1f);
+ *first21++=T2(*first11++*0.2f);
+ *first22++=T2(*first10++*0.3f);
+ }
+ }
+};
+template <typename T1, typename T2, typename F>
+struct transform_nongil_t<RGB_VIEW(T1),RGB_PLANAR_VIEW(T2),F>
+{
+ using View1 = RGB_VIEW(T1);
+ using View2 = RGB_PLANAR_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ F _f;
+ transform_nongil_t(const View1& v1_in,const View2& v2_in,const F& f_in) : _v1(v1_in),_v2(v2_in),_f(f_in) {}
+ void operator()() const {
+ T1* first1=(T1*)_v1.row_begin(0);
+ T1* last1=first1+_v1.size()*3;
+ T1* first20=(T2*)boost::gil::at_c<0>(_v2.row_begin(0));
+ T1* first21=(T2*)boost::gil::at_c<1>(_v2.row_begin(0));
+ T1* first22=(T2*)boost::gil::at_c<2>(_v2.row_begin(0));
+ while(first1!=last1) {
+ *first20++=T2(first1[2]*0.1f);
+ *first21++=T2(first1[1]*0.2f);
+ *first22++=T2(first1[0]*0.3f);
+ first1+=3;
+ }
+ }
+};
+template <typename T1, typename T2, typename F>
+struct transform_nongil_t<RGB_PLANAR_VIEW(T1),RGB_VIEW(T2),F>
+{
+ using View1 = RGB_PLANAR_VIEW(T1);
+ using View2 = RGB_VIEW(T2);
+ View1 _v1;
+ View2 _v2;
+ F _f;
+ transform_nongil_t(const View1& v1_in,const View2& v2_in,const F& f_in) : _v1(v1_in),_v2(v2_in),_f(f_in) {}
+ void operator()() const {
+ T1* first10=(T1*)boost::gil::at_c<0>(_v1.row_begin(0));
+ T1* first11=(T1*)boost::gil::at_c<1>(_v1.row_begin(0));
+ T1* first12=(T1*)boost::gil::at_c<2>(_v1.row_begin(0));
+ T2* first2=(T1*)_v2.row_begin(0);
+ T1* last2=first2+_v1.size()*3;
+ while(first2!=last2) {
+ first2[0]=T2(*first12++*0.1f);
+ first2[1]=T2(*first11++*0.2f);
+ first2[2]=T2(*first10++*0.3f);
+ first2+=3;
+ }
+ }
+};
+
+template <typename View1, typename View2, typename F>
+void test_transform(std::size_t trials) {
+ image<typename View1::value_type, is_planar<View1>::value> im1(width,height);
+ image<typename View2::value_type, is_planar<View2>::value> im2(width,height);
+ //std::cout << "GIL: " <<measure_time(transform_gil_t<View1,View2,F>(view(im1),view(im2),F()),trials) << std::endl;
+ //std::cout << "Non-GIL: "<<measure_time(transform_nongil_t<View1,View2,F>(view(im1),view(im2),F()),trials) << std::endl;
+}
+
+BOOST_AUTO_TEST_SUITE(GIL_Tests)
+
+BOOST_AUTO_TEST_CASE(performance_test)
+{
+#ifdef NDEBUG
+ std::size_t num_trials=1000;
+#else
+ std::size_t num_trials=1;
+#endif
+
+ // fill()
+ std::cout<<"test fill_pixels() on rgb8_image_t with rgb8_pixel_t"<<std::endl;
+ test_fill<rgb8_view_t,rgb8_pixel_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test fill_pixels() on rgb8_planar_image_t with rgb8_pixel_t"<<std::endl;
+ test_fill<rgb8_planar_view_t,rgb8_pixel_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test fill_pixels() on rgb8_image_t with bgr8_pixel_t"<<std::endl;
+ test_fill<rgb8_view_t,bgr8_pixel_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test fill_pixels() on rgb8_planar_image_t with bgr8_pixel_t"<<std::endl;
+ test_fill<rgb8_planar_view_t,bgr8_pixel_t>(num_trials);
+ std::cout<<std::endl;
+
+ // for_each()
+ std::cout<<"test for_each_pixel() on rgb8_image_t"<<std::endl;
+ test_for_each<rgb8_view_t,rgb_fr_t<uint8_t> >(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test for_each_pixel() on rgb8_planar_image_t"<<std::endl;
+ test_for_each<rgb8_planar_view_t,rgb_fr_t<uint8_t> >(num_trials);
+ std::cout<<std::endl;
+
+ // copy()
+ std::cout<<"test copy_pixels() between rgb8_image_t and rgb8_image_t"<<std::endl;
+ test_copy<rgb8_view_t,rgb8_view_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test copy_pixels() between rgb8_image_t and bgr8_image_t"<<std::endl;
+ test_copy<rgb8_view_t,bgr8_view_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test copy_pixels() between rgb8_planar_image_t and rgb8_planar_image_t"<<std::endl;
+ test_copy<rgb8_planar_view_t,rgb8_planar_view_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test copy_pixels() between rgb8_image_t and rgb8_planar_image_t"<<std::endl;
+ test_copy<rgb8_view_t,rgb8_planar_view_t>(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test copy_pixels() between rgb8_planar_image_t and rgb8_image_t"<<std::endl;
+ test_copy<rgb8_planar_view_t,rgb8_view_t>(num_trials);
+ std::cout<<std::endl;
+
+ // transform()
+ std::cout<<"test transform_pixels() between rgb8_image_t and rgb8_image_t"<<std::endl;
+ test_transform<rgb8_view_t,rgb8_view_t,bgr_to_rgb_t<uint8_t,pixel<uint8_t,rgb_layout_t> > >(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test transform_pixels() between rgb8_planar_image_t and rgb8_planar_image_t"<<std::endl;
+ test_transform<rgb8_planar_view_t,rgb8_planar_view_t,bgr_to_rgb_t<uint8_t,planar_pixel_reference<uint8_t,rgb_t> > >(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test transform_pixels() between rgb8_image_t and rgb8_planar_image_t"<<std::endl;
+ test_transform<rgb8_view_t,rgb8_planar_view_t,bgr_to_rgb_t<uint8_t,pixel<uint8_t,rgb_layout_t> > >(num_trials);
+ std::cout<<std::endl;
+
+ std::cout<<"test transform_pixels() between rgb8_planar_image_t and rgb8_image_t"<<std::endl;
+ test_transform<rgb8_planar_view_t,rgb8_view_t,bgr_to_rgb_t<uint8_t,planar_pixel_reference<uint8_t,rgb_t> > >(num_trials);
+ std::cout<<std::endl;
+}
+
+BOOST_AUTO_TEST_SUITE_END()
diff --git a/src/boost/libs/gil/test/legacy/pixel.cpp b/src/boost/libs/gil/test/legacy/pixel.cpp
new file mode 100644
index 00000000..ad1272b3
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/pixel.cpp
@@ -0,0 +1,322 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#include <boost/gil.hpp>
+
+#include <boost/core/ignore_unused.hpp>
+#include <boost/mp11.hpp>
+
+#include <exception>
+#include <iostream>
+#include <iterator>
+#include <type_traits>
+
+using namespace boost::gil;
+using std::swap;
+using namespace boost;
+
+void error_if(bool condition);
+
+struct increment {
+ template <typename Incrementable> void operator()(Incrementable& x) const { ++x; }
+};
+
+struct prev
+{
+ template <typename Subtractable>
+ auto operator()(const Subtractable& x) const -> typename channel_traits<Subtractable>::value_type
+ {
+ using return_type = typename channel_traits<Subtractable>::value_type;
+ return static_cast<return_type>(x - 1);
+ }
+};
+
+struct set_to_one{ int operator()() const { return 1; } };
+
+// Construct with two pixel types. They must be compatible and the second must be mutable
+template <typename C1, typename C2>
+struct do_basic_test : public C1, public C2
+{
+ using pixel1_t = typename C1::type;
+ using pixel2_t = typename C2::type;
+ using pixel1_value_t = typename C1::pixel_t::value_type;
+ using pixel2_value_t = typename C2::pixel_t::value_type;
+ using pixel_value_t = pixel1_value_t;
+
+ do_basic_test(const pixel_value_t& v) : C1(v), C2(v) {}
+
+ void test_all() {
+ test_heterogeneous();
+
+ // test homogeneous algorithms - fill, max, min
+ static const int num_chan = num_channels<typename C2::pixel_t>::value;
+ static_fill(C2::_pixel, gil::at_c<0>(C1::_pixel)+1);
+ error_if(gil::at_c<0>(C2::_pixel) != gil::at_c<num_chan-1>(C2::_pixel));
+
+ C2::_pixel = C1::_pixel;
+ error_if(static_max(C2::_pixel) != static_max(C1::_pixel));
+ error_if(static_min(C2::_pixel) != static_min(C1::_pixel));
+ error_if(static_max(C2::_pixel) < static_min(C2::_pixel));
+
+ // test operator[]
+ C2::_pixel[0] = C1::_pixel[0]+1;
+ error_if(C2::_pixel[0] != C1::_pixel[0]+1);
+ }
+
+ void test_heterogeneous() {
+ // Both must be pixel types (not necessarily pixel values). The second must be mutable. They must be compatible
+ boost::function_requires<PixelConcept<typename C1::pixel_t> >();
+ boost::function_requires<MutablePixelConcept<typename C2::pixel_t> >();
+ boost::function_requires<PixelsCompatibleConcept<typename C1::pixel_t,typename C2::pixel_t> >();
+
+ C2::_pixel = C1::_pixel; // test operator=
+ error_if(C1::_pixel != C2::_pixel); // test operator==
+
+ // construct a pixel value from it
+ pixel1_value_t v1(C1::_pixel);
+ pixel2_value_t v2(C2::_pixel);
+ error_if(v1 != v2);
+
+ // construct from a pixel value
+ pixel1_t c1(v1);
+ pixel2_t c2(v2);
+ error_if(c1 != c2);
+
+ // Invert the first semantic channel.
+ C2::_pixel = C1::_pixel;
+ semantic_at_c<0>(C2::_pixel) = channel_invert(semantic_at_c<0>(C2::_pixel));
+ error_if(C1::_pixel == C2::_pixel); // now they must not be equal
+
+ // test pixel algorithms
+ C2::_pixel = C1::_pixel;
+ static_for_each(C2::_pixel, increment());
+ static_transform(C2::_pixel, C2::_pixel, prev());
+ error_if(C1::_pixel!=C2::_pixel);
+
+ static_generate(C2::_pixel, set_to_one());
+ error_if(gil::at_c<0>(C2::_pixel) != 1);
+
+ // Test swap if both are mutable and if their value type is the same
+ // (We know the second one is mutable)
+ using p1_ref = typename boost::add_reference<typename C1::type>::type;
+ using is_swappable = std::integral_constant
+ <
+ bool,
+ pixel_reference_is_mutable<p1_ref>::value &&
+ std::is_same<pixel1_value_t, pixel2_value_t>::value
+ >;
+ test_swap(is_swappable{});
+ }
+
+ void test_swap(std::false_type) {}
+ void test_swap(std::true_type) {
+ // test swap
+ static_fill(C1::_pixel, 0);
+ static_fill(C2::_pixel, 1);
+ pixel_value_t pv1(C1::_pixel);
+ pixel_value_t pv2(C2::_pixel);
+ error_if(C2::_pixel == C1::_pixel);
+ swap(C1::_pixel, C2::_pixel);
+ error_if(C1::_pixel != pv2 || C2::_pixel != pv1);
+ }
+};
+
+template <typename PixelValue, int Tag=0>
+class value_core
+{
+public:
+ using type = PixelValue;
+ using pixel_t = type;
+ type _pixel;
+
+ value_core() : _pixel(0) {}
+ value_core(const type& val) : _pixel(val) { // test copy constructor
+ boost::function_requires<PixelValueConcept<pixel_t> >();
+ type p2; // test default constructor
+ boost::ignore_unused(p2);
+ }
+};
+
+template <typename PixelRef, int Tag=0>
+class reference_core : public value_core<typename std::remove_reference<PixelRef>::type::value_type, Tag>
+{
+public:
+ using type = PixelRef;
+ using pixel_t = typename boost::remove_reference<PixelRef>::type;
+ using parent_t = value_core<typename pixel_t::value_type, Tag>;
+
+ type _pixel;
+
+ reference_core() : parent_t(), _pixel(parent_t::_pixel) {}
+ reference_core(const typename pixel_t::value_type& val) : parent_t(val), _pixel(parent_t::_pixel) {
+ boost::function_requires<PixelConcept<pixel_t> >();
+ }
+};
+
+// Use a subset of pixel models that covers all color spaces, channel depths, reference/value, planar/interleaved, const/mutable
+// color conversion will be invoked on pairs of them. Having an exhaustive binary check would be too big/expensive.
+using representative_pixels_t = mp11::mp_list
+<
+ value_core<gray8_pixel_t>,
+ reference_core<gray16_pixel_t&>,
+ value_core<bgr8_pixel_t>,
+ reference_core<rgb8_planar_ref_t>,
+ value_core<argb32_pixel_t>,
+ reference_core<cmyk32f_pixel_t&>,
+ reference_core<abgr16c_ref_t>, // immutable reference
+ reference_core<rgb32fc_planar_ref_t>
+>;
+
+template <typename Pixel1>
+struct ccv2 {
+ template <typename P1, typename P2>
+ void color_convert_compatible(const P1& p1, P2& p2, std::true_type) {
+ using value_t = typename P1::value_type;
+ p2 = p1;
+ value_t converted;
+ color_convert(p1, converted);
+ error_if(converted != p2);
+ }
+
+ template <typename P1, typename P2>
+ void color_convert_compatible(const P1& p1, P2& p2, std::false_type) {
+ color_convert(p1,p2);
+ }
+
+ template <typename P1, typename P2>
+ void color_convert_impl(const P1& p1, P2& p2) {
+ using is_compatible = typename pixels_are_compatible<P1,P2>::type;
+ color_convert_compatible(p1, p2, is_compatible());
+ }
+
+ template <typename Pixel2>
+ void operator()(Pixel2) {
+ // convert from Pixel1 to Pixel2 (or, if Pixel2 is immutable, to its value type)
+ using p2_is_mutable = pixel_reference_is_mutable<typename Pixel2::type>;
+ using pixel_model_t = typename std::remove_reference<typename Pixel2::type>::type;
+ using p2_value_t = typename pixel_model_t::value_type;
+ using pixel2_mutable = mp11::mp_if<p2_is_mutable, Pixel2, value_core<p2_value_t>>;
+
+ Pixel1 p1;
+ pixel2_mutable p2;
+
+ color_convert_impl(p1._pixel, p2._pixel);
+ }
+};
+
+struct ccv1 {
+ template <typename Pixel>
+ void operator()(Pixel) {
+ mp11::mp_for_each<representative_pixels_t>(ccv2<Pixel>());
+ }
+};
+
+void test_color_convert() {
+ mp11::mp_for_each<representative_pixels_t>(ccv1());
+}
+
+void test_packed_pixel()
+{
+ using rgb565_pixel_t = packed_pixel_type<uint16_t, mp11::mp_list_c<unsigned,5,6,5>, rgb_layout_t>::type;
+ boost::function_requires<PixelValueConcept<rgb565_pixel_t> >();
+ static_assert(sizeof(rgb565_pixel_t) == 2, "");
+
+ // define a bgr556 pixel
+ using bgr556_pixel_t = packed_pixel_type<uint16_t, mp11::mp_list_c<unsigned,5,6,5>, bgr_layout_t>::type;
+ boost::function_requires<PixelValueConcept<bgr556_pixel_t> >();
+
+ // Create a zero packed pixel and a full regular unpacked pixel.
+ rgb565_pixel_t r565;//((uint16_t)0);
+ rgb8_pixel_t rgb_full(255,255,255);
+
+ // Convert all channels of the unpacked pixel to the packed one & ensure the packed one is full
+ get_color(r565,red_t()) = channel_convert<kth_element_type<rgb565_pixel_t, 0>::type>(get_color(rgb_full,red_t()));
+ get_color(r565,green_t()) = channel_convert<kth_element_type<rgb565_pixel_t, 1>::type>(get_color(rgb_full,green_t()));
+ get_color(r565,blue_t()) = channel_convert<kth_element_type<rgb565_pixel_t, 2>::type>(get_color(rgb_full,blue_t()));
+ error_if(r565 != rgb565_pixel_t((uint16_t)65535));
+
+ // rgb565 is compatible with bgr556. Test interoperability
+ boost::function_requires<PixelsCompatibleConcept<rgb565_pixel_t,bgr556_pixel_t> >();
+
+ do_basic_test<value_core<rgb565_pixel_t,0>, value_core<bgr556_pixel_t,1> >(r565).test_heterogeneous();
+
+ color_convert(r565,rgb_full);
+ color_convert(rgb_full,r565);
+
+ // Test bit-aligned pixel reference
+ using bgr121_ref_t = const bit_aligned_pixel_reference<std::uint8_t, mp11::mp_list_c<int,1,2,1>, bgr_layout_t, true>;
+ using rgb121_ref_t = const bit_aligned_pixel_reference<std::uint8_t, mp11::mp_list_c<int,1,2,1>, rgb_layout_t, true>;
+ using rgb121_pixel_t = rgb121_ref_t::value_type;
+ rgb121_pixel_t p121;
+ do_basic_test<reference_core<bgr121_ref_t,0>, reference_core<rgb121_ref_t,1> >(p121).test_heterogeneous();
+ do_basic_test<value_core<rgb121_pixel_t,0>, reference_core<rgb121_ref_t,1> >(p121).test_heterogeneous();
+
+ static_assert(pixel_reference_is_proxy<rgb8_planar_ref_t>::value, "");
+ static_assert(pixel_reference_is_proxy<bgr121_ref_t>::value, "");
+
+ static_assert(!pixel_reference_is_proxy<rgb8_pixel_t>::value, "");
+ static_assert(!pixel_reference_is_proxy<rgb8_pixel_t&>::value, "");
+ static_assert(!pixel_reference_is_proxy<rgb8_pixel_t const&>::value, "");
+
+ static_assert(pixel_reference_is_mutable<rgb8_pixel_t&>::value, "");
+ static_assert(!pixel_reference_is_mutable<rgb8_pixel_t const&>::value, "");
+
+ static_assert(pixel_reference_is_mutable<rgb8_planar_ref_t>::value, "");
+ static_assert(pixel_reference_is_mutable<rgb8_planar_ref_t const&>::value, "");
+
+ static_assert(!pixel_reference_is_mutable<rgb8c_planar_ref_t>::value, "");
+ static_assert(!pixel_reference_is_mutable<rgb8c_planar_ref_t const&>::value, "");
+
+ static_assert(pixel_reference_is_mutable<bgr121_ref_t>::value, "");
+ static_assert(!pixel_reference_is_mutable<bgr121_ref_t::const_reference>::value, "");
+}
+
+void test_pixel() {
+ test_packed_pixel();
+ rgb8_pixel_t rgb8(1,2,3);
+
+ do_basic_test<value_core<rgb8_pixel_t,0>, reference_core<rgb8_pixel_t&,1> >(rgb8).test_all();
+ do_basic_test<value_core<bgr8_pixel_t,0>, reference_core<rgb8_planar_ref_t,1> >(rgb8).test_all();
+ do_basic_test<reference_core<rgb8_planar_ref_t,0>, reference_core<bgr8_pixel_t&,1> >(rgb8).test_all();
+ do_basic_test<reference_core<const rgb8_pixel_t&,0>, reference_core<rgb8_pixel_t&,1> >(rgb8).test_all();
+
+ test_color_convert();
+
+ // Semantic vs physical channel accessors. Named channel accessors
+ bgr8_pixel_t bgr8(rgb8);
+ error_if(bgr8[0] == rgb8[0]);
+ error_if(dynamic_at_c(bgr8,0) == dynamic_at_c(rgb8,0));
+ error_if(gil::at_c<0>(bgr8) == gil::at_c<0>(rgb8));
+ error_if(semantic_at_c<0>(bgr8) != semantic_at_c<0>(rgb8));
+ error_if(get_color(bgr8,blue_t()) != get_color(rgb8,blue_t()));
+
+ // Assigning a grayscale channel to a pixel
+ gray16_pixel_t g16(34);
+ g16 = 8;
+ uint16_t g = get_color(g16,gray_color_t());
+ error_if(g != 8);
+ error_if(g16 != 8);
+}
+
+
+int main()
+{
+ try
+ {
+ test_pixel();
+ return EXIT_SUCCESS;
+ }
+ catch (std::exception const& e)
+ {
+ std::cerr << e.what() << std::endl;
+ return EXIT_FAILURE;
+ }
+ catch (...)
+ {
+ return EXIT_FAILURE;
+ }
+}
diff --git a/src/boost/libs/gil/test/legacy/pixel_iterator.cpp b/src/boost/libs/gil/test/legacy/pixel_iterator.cpp
new file mode 100644
index 00000000..1b4a6d2a
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/pixel_iterator.cpp
@@ -0,0 +1,355 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#ifdef _MSC_VER
+#pragma warning(disable : 4244) // 'argument': conversion from 'int' to 'unsigned char', possible loss of data
+#endif
+
+#include <boost/gil.hpp>
+
+#include <boost/assert.hpp>
+#include <boost/mp11.hpp>
+
+#include <exception>
+#include <iostream>
+#include <type_traits>
+#include <vector>
+
+using namespace boost::gil;
+using namespace std;
+
+void test_pixel_iterator()
+{
+ boost::function_requires<Point2DConcept<point<int>>>();
+
+ boost::function_requires<MutablePixelIteratorConcept<bgr8_ptr_t> >();
+ boost::function_requires<MutablePixelIteratorConcept<cmyk8_planar_ptr_t> >();
+ boost::function_requires<PixelIteratorConcept<rgb8c_planar_step_ptr_t> >();
+ boost::function_requires<MutableStepIteratorConcept<rgb8_step_ptr_t> >();
+
+ boost::function_requires<MutablePixelLocatorConcept<rgb8_step_loc_t> >();
+ boost::function_requires<PixelLocatorConcept<rgb8c_planar_step_loc_t> >();
+
+ boost::function_requires<MutableStepIteratorConcept<cmyk8_planar_step_ptr_t> >();
+ boost::function_requires<StepIteratorConcept<gray8c_step_ptr_t> >();
+
+ boost::function_requires<MutablePixelLocatorConcept<memory_based_2d_locator<rgb8_step_ptr_t> > >();
+
+ using bgr121_ref_t = bit_aligned_pixel_reference
+ <
+ std::uint8_t,
+ boost::mp11::mp_list_c<int,1,2,1>,
+ bgr_layout_t,
+ true
+ > const;
+ using bgr121_ptr_t = bit_aligned_pixel_iterator<bgr121_ref_t>;
+
+ boost::function_requires<MutablePixelIteratorConcept<bgr121_ptr_t> >();
+ boost::function_requires<PixelBasedConcept<bgr121_ptr_t> >();
+ boost::function_requires<MemoryBasedIteratorConcept<bgr121_ptr_t> >();
+ boost::function_requires<HasDynamicXStepTypeConcept<bgr121_ptr_t> >();
+
+// TEST dynamic_step_t
+ static_assert(std::is_same<cmyk16_step_ptr_t, dynamic_x_step_type<cmyk16_step_ptr_t>::type>::value, "");
+ static_assert(std::is_same<cmyk16_planar_step_ptr_t, dynamic_x_step_type<cmyk16_planar_ptr_t>::type>::value, "");
+
+ static_assert(std::is_same<iterator_type<uint8_t,gray_layout_t,false,false,false>::type,gray8c_ptr_t>::value, "");
+
+// TEST iterator_is_step
+ static_assert(iterator_is_step<cmyk16_step_ptr_t>::value, "");
+ static_assert(iterator_is_step<cmyk16_planar_step_ptr_t>::value, "");
+ static_assert(!iterator_is_step<cmyk16_planar_ptr_t>::value, "");
+
+ using ccv_rgb_g_fn = color_convert_deref_fn<rgb8c_ref_t, gray8_pixel_t>;
+ using ccv_g_rgb_fn = color_convert_deref_fn<gray8c_ref_t, rgb8_pixel_t>;
+ gil_function_requires<PixelDereferenceAdaptorConcept<ccv_rgb_g_fn> >();
+ gil_function_requires<PixelDereferenceAdaptorConcept<deref_compose<ccv_rgb_g_fn,ccv_g_rgb_fn> > >();
+
+ using rgb2gray_ptr = dereference_iterator_adaptor<rgb8_ptr_t, ccv_rgb_g_fn>;
+ static_assert(!iterator_is_step<rgb2gray_ptr>::value, "");
+
+ using rgb2gray_step_ptr = dynamic_x_step_type<rgb2gray_ptr>::type;
+ static_assert(std::is_same<rgb2gray_step_ptr, dereference_iterator_adaptor<rgb8_step_ptr_t, ccv_rgb_g_fn>>::value, "");
+
+ make_step_iterator(rgb2gray_ptr(),2);
+
+ using rgb2gray_step_ptr1 = dereference_iterator_adaptor<rgb8_step_ptr_t, ccv_rgb_g_fn>;
+ static_assert(iterator_is_step<rgb2gray_step_ptr1>::value, "");
+ static_assert(std::is_same<rgb2gray_step_ptr1, dynamic_x_step_type<rgb2gray_step_ptr1>::type>::value, "");
+
+ using rgb2gray_step_ptr2 = memory_based_step_iterator<dereference_iterator_adaptor<rgb8_ptr_t, ccv_rgb_g_fn>>;
+ static_assert(iterator_is_step<rgb2gray_step_ptr2 >::value, "");
+ static_assert(std::is_same<rgb2gray_step_ptr2, dynamic_x_step_type<rgb2gray_step_ptr2>::type>::value, "");
+ make_step_iterator(rgb2gray_step_ptr2(),2);
+
+// bit_aligned iterators test
+
+ // Mutable reference to a BGR232 pixel
+ using bgr232_ref_t = bit_aligned_pixel_reference
+ <
+ std::uint8_t,
+ boost::mp11::mp_list_c<unsigned, 2, 3, 2>,
+ bgr_layout_t,
+ true
+ > const;
+
+ // A mutable iterator over BGR232 pixels
+ using bgr232_ptr_t = bit_aligned_pixel_iterator<bgr232_ref_t>;
+
+ // BGR232 pixel value. It is a packed_pixel of size 1 byte. (The last bit is unused)
+ using bgr232_pixel_t = std::iterator_traits<bgr232_ptr_t>::value_type;
+ static_assert(sizeof(bgr232_pixel_t) == 1, "");
+
+ bgr232_pixel_t red(0,0,3); // = 0RRGGGBB, = 01100000
+
+ // a buffer of 7 bytes fits exactly 8 BGR232 pixels.
+ unsigned char pix_buffer[7];
+ std::fill(pix_buffer,pix_buffer+7,0);
+ bgr232_ptr_t pix_it(&pix_buffer[0],0); // start at bit 0 of the first pixel
+ for (int i=0; i<8; ++i) {
+ *pix_it++ = red;
+ }
+
+ // test cross byte pixel values - meaning when a pixel value is stretched over two bytes
+ using gray3_image_t = bit_aligned_image1_type<3, gray_layout_t>::type;
+ using image_t = gray3_image_t;
+
+ using view_t = image_t::view_t;
+ using ref_t = view_t::reference;
+
+ using iterator_t = bit_aligned_pixel_iterator<ref_t>;
+
+ std::vector< unsigned char > buf( 4 );
+ // bit pattern is: 1011 0110 0110 1101 1101 1011
+ // each byte is read right to left
+ buf[0] = 182;
+ buf[1] = 109;
+ buf[2] = 219;
+
+ iterator_t it( &buf[0], 0 );
+
+ ref_t p1 = *it; it++;
+ ref_t p2 = *it; it++;
+ ref_t p3 = *it; it++;
+ ref_t p4 = *it; it++;
+ ref_t p5 = *it; it++;
+ ref_t p6 = *it; it++;
+ ref_t p7 = *it; it++;
+ ref_t p8 = *it; it++;
+
+ unsigned char v1 = get_color( p1, gray_color_t() );
+ unsigned char v2 = get_color( p2, gray_color_t() );
+ unsigned char v3 = get_color( p3, gray_color_t() );
+ unsigned char v4 = get_color( p4, gray_color_t() );
+ unsigned char v5 = get_color( p5, gray_color_t() );
+ unsigned char v6 = get_color( p6, gray_color_t() );
+ unsigned char v7 = get_color( p7, gray_color_t() );
+ unsigned char v8 = get_color( p8, gray_color_t() );
+
+ // all values should be 110b ( 6 );
+ BOOST_ASSERT(v1 == 6);
+ BOOST_ASSERT(v2 == 6);
+ BOOST_ASSERT(v3 == 6);
+ BOOST_ASSERT(v4 == 6);
+ BOOST_ASSERT(v5 == 6);
+ BOOST_ASSERT(v6 == 6);
+ BOOST_ASSERT(v7 == 6);
+ BOOST_ASSERT(v8 == 6);
+}
+
+// TODO: Make better tests. Use some code from below.
+
+/*
+template <typename Pixel>
+void invert_pixel1(Pixel& pix) {
+ at_c<0>(pix)=0;
+}
+
+template <typename T> inline void ignore_unused_variable_warning(const T&){}
+
+void test_pixel_iterator() {
+ rgb8_pixel_t rgb8(1,2,3);
+ rgba8_pixel_t rgba8;
+
+ rgb8_ptr_t ptr1=&rgb8;
+ memunit_advance(ptr1, 3);
+ const rgb8_ptr_t ptr2=memunit_advanced(ptr1,10);
+
+ memunit_distance(ptr1,ptr2);
+ const rgb8_pixel_t& ref=memunit_advanced_ref(ptr1,10); ignore_unused_variable_warning(ref);
+
+ rgb8_planar_ptr_t planarPtr1(&rgb8);
+ rgb8_planar_ptr_t planarPtr2(&rgb8);
+ memunit_advance(planarPtr1,10);
+ memunit_distance(planarPtr1,planarPtr2);
+ rgb8_planar_ptr_t planarPtr3=memunit_advanced(planarPtr1,10);
+
+// planarPtr2=&rgba8;
+
+ planar_pixel_reference<uint8_t&,rgb_t> pxl=*(planarPtr1+5);
+ rgb8_pixel_t pv2=pxl;
+ rgb8_pixel_t pv3=*(planarPtr1+5);
+ rgb8_pixel_t pv=planarPtr1[5];
+
+ assert(*(planarPtr1+5)==planarPtr1[5]);
+
+ rgb8_planar_ref_t planarRef=memunit_advanced_ref(planarPtr1,10);
+
+ rgb8_step_ptr_t stepIt(&rgb8,5);
+ stepIt++;
+ rgb8_step_ptr_t stepIt2=stepIt+10;
+ stepIt2=stepIt;
+
+ rgb8_step_ptr_t stepIt3(&rgb8,5);
+
+ rgb8_pixel_t& ref1=stepIt3[5];
+// bool v=std::is_pod<iterator_traits<memory_based_step_iterator<rgb8_ptr_t> >::value_type>::value;
+// v=std::is_pod<rgb8_pixel_t>::value;
+// v=std::is_pod<int>::value;
+
+ rgb8_step_ptr_t rgb8StepIt(ptr1, 10);
+ rgb8_step_ptr_t rgb8StepIt2=rgb8StepIt;
+ rgb8StepIt=rgb8StepIt2;
+ ++rgb8StepIt;
+ rgb8_ref_t reff=*rgb8StepIt; ignore_unused_variable_warning(reff);
+ rgb8StepIt+=10;
+ std::ptrdiff_t dst=rgb8StepIt2-rgb8StepIt; ignore_unused_variable_warning(dst);
+
+ rgb8_pixel_t val1=ref1;
+ rgb8_ptr_t ptr=&ref1;
+
+ invert_pixel1(*planarPtr1);
+// invert_pixel1(*ptr);
+ rgb8c_planar_ptr_t r8cpp;
+// invert_pixel1(*r8cpp);
+
+ rgb8_pixel_t& val21=stepIt3[5];
+ rgb8_pixel_t val22=val21;
+
+ rgb8_pixel_t val2=stepIt3[5];
+ rgb8_ptr_t ptr11=&(stepIt3[5]); ignore_unused_variable_warning(ptr11);
+ rgb8_ptr_t ptr3=&*(stepIt3+5); ignore_unused_variable_warning(ptr3);
+
+ rgb8_step_ptr_t stepIt4(ptr,5);
+ ++stepIt4;
+
+ rgb8_step_ptr_t stepIt5;
+ if (stepIt4==stepIt5) {
+ int st=0;ignore_unused_variable_warning(st);
+ }
+
+ iterator_from_2d<rgb8_loc_t> pix_img_it(rgb8_loc_t(ptr, 20), 5);
+ ++pix_img_it;
+ pix_img_it+=10;
+ rgb8_pixel_t& refr=*pix_img_it;
+ refr=rgb8_pixel_t(1,2,3);
+ *pix_img_it=rgb8_pixel_t(1,2,3);
+ pix_img_it[3]=rgb8_pixel_t(1,2,3);
+ *(pix_img_it+3)=rgb8_pixel_t(1,2,3);
+
+ iterator_from_2d<rgb8c_loc_t> pix_img_it_c(rgb8c_loc_t(rgb8c_ptr_t(ptr),20), 5);
+ ++pix_img_it_c;
+ pix_img_it_c+=10;
+ // *pix_img_it_c=rgb8_pixel_t(1,2,3); // error: assigning though const iterator
+ using dif_t = iterator_from_2d<rgb8_loc_t>::difference_type;
+ dif_t dt=0;
+ std::ptrdiff_t tdt=dt; ignore_unused_variable_warning(tdt);
+
+ // memory_based_step_iterator<rgb8_pixel_t> stepIt3Err=stepIt+10; // error: non-const from const iterator
+
+ memory_based_2d_locator<rgb8_step_ptr_t> xy_locator(ptr,27);
+
+ xy_locator.x()++;
+// memory_based_step_iterator<rgb8_pixel_t>& yit=xy_locator.y();
+ xy_locator.y()++;
+ xy_locator+=point<std::ptrdiff_t>(3,4);
+ // *xy_locator=(xy_locator(-1,0)+xy_locator(0,1))/2;
+ rgb8_pixel_t& rf=*xy_locator; ignore_unused_variable_warning(rf);
+
+ make_step_iterator(rgb8_ptr_t(),3);
+ make_step_iterator(rgb8_planar_ptr_t(),3);
+ make_step_iterator(rgb8_planar_step_ptr_t(),3);
+
+ // Test operator-> on planar ptrs
+ {
+ rgb8c_planar_ptr_t cp(&rgb8);
+ rgb8_planar_ptr_t p(&rgb8);
+// get_color(p,red_t()) = get_color(cp,green_t()); // does not compile - cannot assign a non-const pointer to a const pointer. Otherwise you will be able to modify the value through it.
+ }
+// xy_locator.y()++;
+
+ // dimensions to explore
+ //
+ // values, references, pointers
+ // color spaces (rgb,cmyk,gray)
+ // channel ordering (bgr vs rgb)
+ // planar vs interleaved
+
+// Pixel POINTERS
+// using RGB8ConstPtr = iterator_traits<rgb8_ptr_t>::pointer const;
+ using RGB8ConstPtr = rgb8_ptr_t const;
+ using RGB8ConstPlanarPtr = rgb8_planar_ptr_t const;
+// using RGB8ConstPlanarPtr = iterator_traits<rgb8_planar_ptr_t>::pointer const;
+
+// constructing from values, references and other pointers
+ RGB8ConstPtr rgb8_const_ptr=NULL; ignore_unused_variable_warning(rgb8_const_ptr);
+ rgb8_ptr_t rgb8ptr=&rgb8;
+
+ rgb8=bgr8_pixel_t(30,20,10);
+ rgb8_planar_ptr_t rgb8_pptr=&rgb8;
+ ++rgb8_pptr;
+ rgb8_pptr--;
+ rgb8_pptr[0]=rgb8;
+ RGB8ConstPlanarPtr rgb8_const_planar_ptr=&rgb8;
+
+ rgb8c_planar_ptr_t r8c=&rgb8;
+ r8c=&rgb8;
+
+ rgb8_pptr=&rgb8;
+
+ // rgb8_const_planar_ptr=&rgb16p; // error: incompatible bit depth
+
+ // iterator_traits<CMYK8>::pointer cmyk8_ptr_t=&rgb8; // error: incompatible pointer type
+
+ RGB8ConstPtr rgb8_const_ptr_err=rgb8ptr; // const pointer from non-regular pointer
+ignore_unused_variable_warning(rgb8_const_ptr_err);
+// dereferencing pointers to obtain references
+ rgb8_ref_t rgb8ref_2=*rgb8ptr; ignore_unused_variable_warning(rgb8ref_2);
+ assert(rgb8ref_2==rgb8);
+ // RGB8Ref rgb8ref_2_err=*rgb8_const_planar_ptr; // error: non-const reference from const pointer
+
+ rgb8_planar_ref_t rgb8planarref_3=*rgb8_pptr; // planar reference from planar pointer
+ assert(rgb8planarref_3==rgb8);
+ // RGB8Ref rgb8ref_3=*rgb8_planar_ptr_t; // error: non-planar reference from planar pointer
+
+ const rgb8_pixel_t crgb8=rgb8;
+ *rgb8_pptr=rgb8;
+ *rgb8_pptr=crgb8;
+
+ memunit_advance(rgb8_pptr,3);
+ memunit_advance(rgb8_pptr,-3);
+}
+*/
+
+int main()
+{
+ try
+ {
+ test_pixel_iterator();
+
+ return EXIT_SUCCESS;
+ }
+ catch (std::exception const& e)
+ {
+ std::cerr << e.what() << std::endl;
+ return EXIT_FAILURE;
+ }
+ catch (...)
+ {
+ return EXIT_FAILURE;
+ }
+}
diff --git a/src/boost/libs/gil/test/legacy/recreate_image.cpp b/src/boost/libs/gil/test/legacy/recreate_image.cpp
new file mode 100644
index 00000000..eec4e3d3
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/recreate_image.cpp
@@ -0,0 +1,105 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#ifdef _MSC_VER
+//#pragma warning(disable : 4244) // conversion from 'gil::image<V,Alloc>::coord_t' to 'int', possible loss of data (visual studio compiler doesn't realize that the two types are the same)
+#pragma warning(disable : 4503) // decorated name length exceeded, name was truncated
+#endif
+
+#include <boost/gil/extension/dynamic_image/dynamic_image_all.hpp>
+
+#include <boost/test/unit_test.hpp>
+
+#include <ios>
+#include <iostream>
+#include <fstream>
+#include <map>
+#include <string>
+#include <type_traits>
+#include <vector>
+
+using namespace boost::gil;
+using namespace std;
+using namespace boost;
+
+///////////////////////////////////////////////////////////////
+
+std::size_t is_planar_impl( const std::size_t size_in_units
+ , const std::size_t channels_in_image
+ , std::true_type
+ )
+{
+ return size_in_units * channels_in_image;
+}
+
+std::size_t is_planar_impl( const std::size_t size_in_units
+ , const std::size_t
+ , std::false_type
+ )
+{
+ return size_in_units;
+}
+
+template< typename View >
+std::size_t get_row_size_in_memunits( typename View::x_coord_t width)
+{ // number of units per row
+ std::size_t size_in_memunits = width * memunit_step( typename View::x_iterator() );
+
+ return size_in_memunits;
+}
+
+
+template< typename View
+ , bool IsPlanar
+ >
+std::size_t total_allocated_size_in_bytes( const typename View::point_t& dimensions )
+{
+
+ using x_iterator = typename View::x_iterator;
+
+ // when value_type is a non-pixel, like int or float, num_channels< ... > doesn't work.
+ const std::size_t _channels_in_image = mp11::mp_eval_if< is_pixel< typename View::value_type >
+ , num_channels< View >
+ , std::integral_constant<int, 1>
+ >::type::value;
+
+ std::size_t size_in_units = is_planar_impl( get_row_size_in_memunits< View >( dimensions.x ) * dimensions.y
+ , _channels_in_image
+ , typename std::conditional< IsPlanar, std::true_type, std::false_type >::type()
+ );
+
+ // return the size rounded up to the nearest byte
+ std::size_t btm = byte_to_memunit< typename View::x_iterator >::value;
+
+
+ return ( size_in_units + btm - 1 )
+ / btm;
+}
+
+
+BOOST_AUTO_TEST_SUITE(GIL_Tests)
+
+BOOST_AUTO_TEST_CASE(recreate_image_test)
+{
+ auto tasib_1 = total_allocated_size_in_bytes<rgb8_view_t, false>({640, 480});
+ auto tasib_2 = total_allocated_size_in_bytes<rgb8_view_t, false>({320, 200});
+
+ rgb8_image_t img( 640, 480 );
+ img.recreate( 320, 200 );
+
+}
+
+BOOST_AUTO_TEST_SUITE_END()
+
+#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
+#pragma warning(push)
+#pragma warning(disable:4127) //conditional expression is constant
+#endif
+
+#if BOOST_WORKAROUND(BOOST_MSVC, >= 1400)
+#pragma warning(pop)
+#endif
diff --git a/src/boost/libs/gil/test/legacy/sample_image.cpp b/src/boost/libs/gil/test/legacy/sample_image.cpp
new file mode 100644
index 00000000..bbcdf017
--- /dev/null
+++ b/src/boost/libs/gil/test/legacy/sample_image.cpp
@@ -0,0 +1,159 @@
+//
+// Copyright 2005-2007 Adobe Systems Incorporated
+//
+// Distributed under the Boost Software License, Version 1.0
+// See accompanying file LICENSE_1_0.txt or copy at
+// http://www.boost.org/LICENSE_1_0.txt
+//
+#include <boost/gil.hpp>
+
+unsigned char halfdome[][3174]={
+{
+ 47,47,48,48,48,48,48,47,51,50,49,51,50,60,110,150,143,93,164,168,125,137,53,54,56,54,52,50,52,51,50,51,53,52,51,51,52,53,51,51,52,52,51,51,50,52,51,53,51,52,51,53,52,54,57,57,59,57,59,59,60,60,177,185,206,221,230,224,227,
+ 50,52,48,51,50,51,52,51,53,51,53,53,56,54,59,59,61,64,149,149,153,65,58,57,57,57,55,55,56,57,55,57,56,56,53,54,56,55,53,55,54,56,56,55,54,54,56,54,55,57,56,54,57,57,59,70,178,75,67,191,132,194,226,201,226,226,227,237,222,
+ 54,54,55,54,53,54,55,54,56,58,57,59,59,59,59,61,61,61,62,64,65,65,85,61,58,59,60,61,60,61,58,60,58,60,59,60,59,58,60,60,57,59,59,58,60,61,59,57,58,60,60,62,61,63,192,210,223,223,231,222,226,218,208,204,205,206,205,215,207,
+ 58,57,57,59,58,58,60,58,60,60,59,58,62,63,64,64,62,63,66,66,67,67,65,66,64,62,64,61,62,63,65,64,63,63,64,60,63,63,62,64,62,64,63,65,63,64,63,62,61,64,63,84,119,69,146,179,202,221,217,208,205,209,206,212,201,182,178,184,183,
+ 60,61,62,60,61,64,64,62,65,63,65,66,69,65,66,67,69,67,69,69,67,70,71,70,69,69,68,68,67,70,70,69,69,68,69,67,66,68,67,75,70,67,89,65,67,67,67,66,66,67,68,78,93,159,188,178,161,185,196,215,196,187,174,172,170,174,175,171,171,
+ 66,66,65,66,68,69,67,68,67,70,68,70,72,72,73,73,73,73,74,75,75,75,76,74,75,75,74,75,76,75,75,74,75,75,74,75,76,90,157,157,158,177,163,182,161,72,76,70,71,71,72,74,75,80,117,129,143,166,200,194,191,210,215,200,182,181,176,182,196,
+ 72,72,71,72,72,71,74,72,74,73,73,77,77,78,77,79,77,80,78,79,82,80,81,92,81,91,80,80,81,81,81,79,81,79,116,123,103,96,87,80,105,115,140,82,97,97,130,169,162,124,77,78,80,79,81,83,83,142,192,202,211,182,203,191,194,176,169,184,184,
+ 75,76,75,73,77,77,79,76,79,77,79,80,81,84,84,83,85,86,87,166,241,96,89,88,89,88,100,88,88,87,92,203,91,173,178,162,179,87,86,85,83,84,84,82,83,82,85,83,85,94,81,83,81,83,84,135,183,187,192,176,180,208,193,216,203,196,196,207,191,
+ 79,80,79,81,81,82,82,86,83,84,85,88,89,95,244,238,93,128,222,227,245,248,231,99,159,98,183,196,95,97,183,215,215,223,230,230,228,117,92,90,90,90,88,87,87,86,87,87,88,86,89,89,90,91,101,231,214,189,221,165,166,192,184,193,194,176,170,159,157,
+ 84,84,86,86,86,88,88,88,90,90,91,94,217,244,246,248,249,188,223,223,224,231,232,222,226,218,189,171,190,199,223,179,199,204,205,202,203,205,188,101,97,93,94,93,93,95,96,106,115,97,96,98,209,234,217,224,242,242,242,217,214,191,139,183,179,179,164,154,143,
+ 89,89,89,92,91,91,93,95,94,96,115,226,208,212,235,241,245,212,196,200,201,209,203,192,183,187,219,192,198,211,214,224,200,197,184,181,186,203,190,218,189,131,173,189,160,188,173,175,185,197,199,201,192,237,211,196,225,241,242,230,238,222,222,221,218,188,168,184,197,
+ 95,98,98,98,99,101,102,161,161,143,215,193,232,200,200,204,227,208,228,214,212,226,48,195,213,193,191,203,201,206,229,232,210,183,225,221,234,232,234,197,206,189,204,200,193,201,191,200,206,215,223,202,196,186,189,181,209,211,215,183,236,232,176,209,217,231,181,177,178,
+ 103,101,105,106,153,171,197,209,204,218,184,169,199,197,210,213,202,209,215,222,234,203,120,41,195,197,187,197,186,208,193,198,198,196,197,200,201,198,202,210,222,190,178,198,211,232,226,220,204,189,190,199,188,194,193,170,169,187,190,209,225,219,208,225,212,207,199,191,203,
+ 109,109,111,150,205,175,184,193,175,161,165,121,134,130,126,160,203,190,184,161,147,204,61,89,193,201,198,185,215,192,183,193,189,209,189,174,172,172,170,178,197,188,186,214,227,229,143,163,160,182,193,207,189,209,190,191,176,184,197,171,180,181,207,218,218,212,176,170,170,
+ 118,182,143,213,169,184,183,192,201,179,193,212,203,182,154,196,205,163,201,193,191,117,59,45,179,193,228,204,203,186,202,189,159,162,166,180,195,195,191,218,205,177,201,200,199,204,228,183,202,209,202,203,199,212,217,189,207,183,186,192,188,188,175,177,183,179,186,179,184,
+ 126,155,183,185,189,188,185,197,175,183,192,192,188,151,172,86,190,196,184,178,128,111,57,56,135,192,188,198,195,150,180,202,214,224,211,205,182,197,199,195,211,196,181,194,206,194,194,194,192,211,197,198,201,191,197,194,197,192,189,186,181,177,169,190,171,163,171,175,160,
+ 133,134,136,136,163,146,116,166,186,181,205,201,93,132,137,198,207,190,69,119,127,110,70,66,153,192,180,164,168,179,188,199,189,177,183,188,189,160,177,190,194,193,192,194,124,175,193,186,178,180,207,209,187,178,144,97,131,159,105,200,114,125,135,141,179,199,172,108,117,
+ 120,151,138,128,163,112,124,96,103,139,102,149,213,197,208,214,193,80,104,154,107,125,84,63,141,161,163,175,183,186,190,183,201,79,86,204,191,207,194,207,184,169,141,146,171,181,128,125,83,91,101,114,127,163,120,119,114,122,126,140,87,115,113,125,186,104,83,68,84,
+ 118,133,167,92,126,109,124,173,137,181,150,147,166,203,176,178,82,81,123,109,137,146,60,56,146,193,156,175,180,175,194,203,185,178,82,84,74,113,105,65,64,127,65,70,140,92,83,82,80,80,82,79,84,74,99,138,84,76,109,77,142,123,76,83,71,74,55,54,34,
+ 182,127,117,134,158,163,201,189,166,149,192,147,191,164,175,165,120,174,99,109,167,130,153,62,180,131,96,193,203,204,191,215,183,141,70,70,66,68,73,73,71,61,74,85,95,66,63,133,154,135,89,113,89,102,69,124,68,85,77,56,51,72,94,34,60,37,90,39,34,
+ 149,167,135,154,108,173,152,148,184,153,157,182,167,194,176,161,202,148,120,132,149,174,156,125,147,74,133,220,225,187,116,218,209,216,70,69,72,68,61,59,60,63,70,73,63,64,81,59,84,99,80,95,70,90,52,76,162,144,87,67,65,68,98,116,90,55,140,156,58,
+ 91,120,142,143,157,191,188,196,151,209,199,189,177,188,81,77,44,102,112,126,155,70,200,127,88,107,87,59,95,101,153,145,203,188,62,129,124,63,66,58,60,62,67,58,60,68,62,63,77,64,63,64,71,130,97,92,105,72,67,71,158,166,144,152,160,127,125,140,115,
+ 133,164,135,143,168,172,196,181,211,206,197,165,144,56,91,59,46,57,65,157,146,89,177,128,59,53,76,59,63,58,132,122,126,183,209,68,59,74,69,74,77,76,78,49,57,57,72,64,67,81,100,69,146,137,153,69,140,166,83,173,175,169,171,166,41,149,154,120,172,
+ 101,131,158,153,167,86,82,193,163,204,140,129,105,111,44,46,32,157,150,190,120,52,120,163,144,71,68,84,81,87,160,160,106,123,121,97,69,75,79,70,60,57,73,60,61,61,94,77,73,131,115,126,121,96,130,169,128,128,145,180,159,64,139,106,147,45,27,33,20,
+ 67,80,168,201,199,68,148,210,111,132,85,63,139,88,101,60,92,96,66,104,76,47,103,165,115,82,49,89,113,88,127,168,178,133,81,90,84,60,63,105,64,80,64,67,54,62,70,89,88,57,86,129,159,154,202,146,143,126,60,57,69,66,144,32,28,33,62,27,35,
+ 98,101,82,151,129,73,80,129,134,102,116,66,81,53,87,110,95,87,144,69,123,118,106,95,88,69,69,108,91,151,158,132,137,71,158,179,184,145,65,72,64,91,72,73,76,65,60,52,57,63,119,73,67,128,114,80,123,134,172,158,108,114,28,27,28,22,33,27,52,
+ 158,127,109,79,90,75,74,169,97,94,124,61,121,160,171,150,102,60,47,115,136,121,155,81,142,141,135,114,114,144,78,118,79,76,67,123,90,125,77,148,103,77,68,96,73,68,50,62,60,98,101,113,117,117,122,143,97,51,64,60,51,28,37,44,35,30,40,52,74,
+ 139,174,90,111,108,143,123,135,128,113,129,123,139,132,96,55,47,57,69,95,102,76,124,76,52,59,148,131,119,68,86,152,100,105,128,89,139,116,118,131,125,151,93,66,66,61,61,61,58,65,81,68,87,88,102,96,90,111,72,71,79,29,42,37,46,44,49,61,96,
+ 128,159,122,75,55,64,168,129,93,116,109,122,140,149,161,48,58,55,93,96,87,122,76,74,57,66,144,143,57,61,87,130,96,115,131,54,105,117,87,89,79,168,139,156,108,106,80,60,60,87,69,101,85,72,66,90,84,91,91,101,127,41,37,65,65,48,30,70,128,
+ 153,175,59,54,52,155,159,113,143,118,113,127,149,121,148,81,162,97,120,140,57,51,57,58,80,56,124,164,81,58,100,140,60,112,118,98,106,93,65,89,65,129,61,144,119,182,171,78,148,70,101,91,85,90,78,106,89,109,118,131,117,54,75,100,86,47,78,181,134,
+ 60,50,51,52,48,148,87,156,170,141,146,159,77,51,144,174,102,112,161,49,58,73,46,63,64,63,60,135,129,122,87,121,122,174,105,79,96,55,56,60,108,39,46,67,51,144,123,136,59,91,80,99,84,62,92,101,103,99,128,136,215,127,110,139,121,74,135,181,175,
+ 55,51,55,54,105,173,137,149,186,92,84,79,91,92,96,190,101,164,72,50,75,51,67,56,72,93,118,53,63,57,82,159,182,150,127,53,57,69,59,58,54,62,78,71,96,132,90,72,55,63,83,119,86,131,65,66,114,140,95,130,160,135,158,124,133,94,135,147,140,
+ 56,64,47,127,175,145,131,132,178,110,84,71,127,64,136,118,93,86,139,66,116,79,55,64,50,80,133,72,95,161,164,163,163,106,68,52,58,40,60,42,42,84,86,110,88,129,73,72,43,49,49,84,116,93,78,76,132,110,147,126,122,132,82,139,138,79,62,175,158,
+ 50,53,56,59,170,124,166,103,147,89,116,125,101,126,122,156,100,151,165,128,146,54,73,143,66,128,147,149,145,139,144,162,161,109,94,55,46,85,54,57,69,47,63,59,127,65,85,44,99,71,55,70,37,87,119,109,70,122,161,145,148,179,129,119,77,129,134,160,141,
+ 99,53,76,140,161,77,119,137,163,68,89,92,58,138,122,153,129,88,137,134,134,99,95,116,130,117,155,120,136,108,165,158,207,58,87,77,43,55,51,119,59,43,71,63,83,61,86,45,34,72,112,59,162,56,39,66,124,132,139,201,164,172,69,75,92,89,139,150,50,
+ 48,49,56,85,83,51,103,106,118,87,104,190,118,110,143,154,74,144,119,103,117,109,155,141,102,104,96,134,111,89,155,154,121,66,43,42,31,41,54,53,70,52,62,47,97,102,71,57,48,42,60,77,84,72,49,62,56,121,67,173,55,203,53,95,56,54,57,103,57,
+ 48,55,119,169,97,101,106,123,84,55,144,135,116,143,84,114,116,148,102,128,104,114,109,65,93,104,106,164,128,128,145,185,115,51,135,165,75,70,112,152,108,92,57,55,60,59,54,57,120,86,69,136,110,132,62,73,78,88,72,94,57,92,168,55,107,53,43,50,28,
+ 51,51,66,75,71,56,127,117,50,100,145,138,100,128,73,158,105,112,112,170,102,66,92,107,144,140,142,146,147,167,140,116,135,126,175,126,75,118,95,115,62,117,105,70,80,46,75,105,121,127,112,56,89,101,109,52,102,53,51,81,55,157,144,130,47,42,63,82,47,
+ 76,57,122,66,98,54,48,82,65,133,111,135,108,92,146,48,147,123,146,103,102,94,140,100,90,112,100,146,148,151,171,117,160,114,135,128,95,121,129,105,83,128,135,82,118,91,81,60,102,121,107,97,89,117,93,51,52,35,72,48,59,55,57,41,38,56,60,7,24,
+ 97,144,102,119,53,129,63,74,104,145,134,70,109,108,131,103,86,106,108,67,115,92,127,109,66,81,160,128,165,177,120,123,157,78,114,95,149,161,102,135,94,115,129,127,108,66,64,100,84,156,127,67,89,128,88,123,38,35,42,41,50,58,47,57,134,130,111,68,68,
+ 115,121,134,46,126,62,107,158,98,79,113,72,82,147,149,109,117,120,103,109,127,109,130,119,92,103,175,143,124,140,110,111,57,110,124,103,128,142,122,83,109,94,152,92,105,101,46,86,88,131,160,88,108,89,88,156,128,66,59,56,69,83,71,100,76,106,116,43,28,
+ 118,115,62,176,98,129,95,67,62,60,88,77,90,100,113,71,83,141,88,124,124,130,102,125,103,139,109,117,179,128,54,75,102,65,158,117,124,60,112,54,71,168,127,62,145,62,107,87,98,90,136,79,130,147,126,113,69,60,116,50,78,84,80,80,57,132,117,34,101,
+ 126,86,127,113,141,148,92,74,81,58,60,62,118,118,49,68,152,116,125,170,119,115,148,125,119,53,87,156,78,145,71,134,52,105,101,80,50,54,93,49,124,107,107,101,55,64,72,113,64,105,133,143,93,137,157,118,70,29,61,76,60,78,105,59,48,53,42,123,70,
+ 45,49,104,155,135,81,157,85,73,139,91,63,99,116,84,107,59,60,144,108,69,122,128,120,144,65,96,116,121,136,152,120,91,130,144,104,63,51,64,104,78,148,78,50,53,59,64,110,75,97,133,162,85,105,146,48,118,110,88,95,52,58,59,74,42,44,7,61,67,
+ 47,49,75,70,86,99,80,63,174,60,94,121,66,87,115,31,50,111,118,97,101,101,121,110,128,97,131,168,125,134,155,79,150,134,103,68,97,59,86,105,125,140,124,113,40,50,53,82,72,84,104,120,154,162,42,61,35,77,60,42,103,78,58,107,52,52,8,28,59,
+ 49,44,44,40,69,203,93,106,97,105,98,131,68,112,131,112,119,153,80,88,94,108,126,151,133,115,153,124,141,147,115,88,116,62,132,112,133,69,66,130,151,163,66,58,82,92,73,57,103,115,95,156,118,158,62,65,51,93,32,88,55,103,100,120,81,47,66,29,38,
+},
+{
+ 93,93,93,93,93,94,94,94,93,94,95,94,95,100,129,161,158,123,175,178,145,151,98,96,96,96,96,97,95,96,96,95,96,94,95,95,96,95,96,94,94,95,95,96,96,95,96,96,96,96,96,97,98,97,97,99,99,102,100,101,102,104,193,199,213,228,236,229,233,
+ 96,96,97,97,96,97,97,97,97,99,99,99,99,101,100,102,104,106,163,163,162,109,102,100,101,100,101,100,100,99,100,99,100,100,100,100,100,100,99,99,99,100,99,99,99,100,99,99,100,100,100,100,100,100,102,107,186,108,108,195,143,205,229,211,233,234,235,242,231,
+ 100,101,101,101,101,102,102,102,102,102,102,103,103,105,105,106,106,106,107,109,108,108,119,106,106,105,105,105,104,104,104,104,104,104,104,102,104,104,103,103,103,102,103,103,102,103,103,103,104,103,102,103,104,106,198,218,227,228,235,224,231,226,215,211,213,213,214,224,215,
+ 105,105,105,105,106,106,106,107,107,107,108,108,108,108,109,110,111,110,110,111,111,111,111,111,111,111,111,110,109,110,109,110,109,109,108,109,108,107,108,107,108,107,107,107,107,106,107,107,107,107,107,121,133,112,162,188,211,226,223,217,214,217,214,219,209,192,188,194,193,
+ 110,110,110,110,111,111,111,112,112,113,113,114,113,114,114,114,114,114,114,115,116,115,116,116,116,116,116,115,115,115,114,115,115,115,114,114,114,113,113,116,114,114,123,114,112,112,113,113,112,112,113,118,131,176,195,187,175,195,204,220,204,191,184,183,181,186,185,181,178,
+ 115,115,116,115,115,115,116,116,117,117,118,118,119,119,118,120,120,120,120,121,121,121,122,122,122,121,121,121,120,122,122,121,120,121,120,119,121,128,165,166,166,185,171,189,169,117,119,118,118,118,119,119,122,124,150,153,163,176,208,202,199,218,220,205,189,190,186,192,205,
+ 119,120,120,120,121,122,121,122,122,123,123,123,123,125,125,126,126,125,126,128,128,129,129,132,128,132,129,128,128,128,128,128,128,128,144,148,136,133,130,127,140,145,156,127,133,135,157,176,170,145,123,123,124,125,127,128,129,161,200,204,214,190,212,200,200,186,179,196,193,
+ 124,125,125,126,126,126,126,127,127,128,128,130,131,131,131,133,132,132,134,168,242,138,137,136,136,136,141,135,135,135,136,206,137,180,185,173,185,133,131,131,130,130,130,130,132,129,129,131,131,134,129,130,131,131,132,160,193,195,199,186,190,215,201,224,211,204,204,213,199,
+ 130,131,131,131,131,131,132,132,133,134,134,135,137,140,246,242,139,156,227,231,245,248,234,144,168,143,195,208,143,142,192,220,218,223,234,234,229,148,139,138,137,136,136,135,135,135,134,134,135,136,136,136,137,139,143,235,218,195,221,183,184,200,190,200,203,187,181,172,169,
+ 134,135,136,136,137,137,137,138,138,140,140,142,225,246,248,249,250,195,227,228,226,232,235,224,229,222,197,178,195,202,225,187,204,208,208,205,208,208,194,145,143,142,142,142,142,141,143,147,148,143,143,143,220,237,222,228,243,243,243,221,219,198,165,192,189,189,175,163,156,
+ 141,141,142,142,142,143,144,144,145,145,151,230,212,217,240,243,247,218,201,204,205,212,207,198,189,192,220,197,202,214,218,227,204,202,190,188,194,205,194,219,193,161,181,196,174,198,183,185,192,202,203,207,206,237,215,202,230,242,243,231,238,224,226,225,220,196,178,191,200,
+ 147,147,147,147,148,149,151,180,178,164,219,199,236,206,205,208,230,212,228,217,217,230,62,187,211,194,191,199,199,207,230,233,214,190,226,222,234,233,234,200,209,194,206,202,196,202,194,203,209,219,224,204,198,192,193,188,213,215,214,188,240,235,185,212,223,233,188,184,187,
+ 151,152,153,154,171,182,204,214,209,221,193,183,204,201,213,215,206,214,218,225,232,206,124,57,195,197,182,185,177,200,197,199,199,199,202,205,205,203,206,213,222,196,188,200,212,232,226,221,205,197,195,202,192,198,197,177,177,192,196,212,226,221,212,225,213,209,202,196,209,
+ 157,158,159,169,207,186,193,199,187,178,179,163,165,164,163,169,207,199,190,169,147,209,72,95,193,197,192,181,212,190,191,198,195,211,195,182,178,180,176,183,201,191,192,215,226,229,172,183,181,191,198,209,195,209,193,198,184,191,201,178,187,186,210,218,219,214,183,178,180,
+ 163,191,169,218,182,194,193,201,205,193,202,214,208,192,173,200,209,173,200,190,192,120,67,60,183,189,216,198,195,180,189,190,168,170,177,185,199,199,195,220,206,189,205,205,203,208,228,194,206,211,203,207,202,212,218,194,208,189,191,194,195,194,183,185,188,187,192,186,190,
+ 168,175,191,195,196,195,193,202,188,190,200,200,195,175,184,109,192,199,186,175,135,121,69,68,137,189,180,196,186,148,177,191,215,225,212,207,189,200,203,200,213,199,189,198,207,198,196,198,196,211,200,200,203,196,200,198,201,196,194,192,188,184,178,194,181,173,178,181,170,
+ 173,173,173,173,163,171,130,180,193,188,209,207,101,138,139,191,199,200,86,121,130,115,79,77,155,189,172,162,166,179,181,190,195,187,188,194,195,174,186,197,201,200,198,197,137,186,197,193,187,188,207,210,194,184,161,119,147,168,130,204,130,146,147,145,179,202,183,129,127,
+ 132,155,139,136,166,129,123,109,115,149,111,150,207,188,209,215,207,98,106,154,108,127,89,75,140,163,164,175,180,185,181,177,176,94,100,206,196,207,191,203,184,172,145,147,172,180,136,130,103,105,113,125,142,162,131,132,129,137,138,143,106,123,122,140,182,111,97,90,100,
+ 128,141,168,108,135,124,130,175,144,176,149,153,169,210,178,182,106,96,121,112,138,148,68,66,149,190,152,172,177,166,180,195,179,177,94,98,91,118,113,84,84,130,81,87,143,105,101,100,98,97,97,98,99,96,114,140,104,99,122,96,148,130,96,98,90,90,79,77,54,
+ 179,141,130,151,164,162,199,192,164,150,193,149,191,169,175,169,126,164,101,113,169,132,149,73,178,132,101,188,199,189,182,208,175,138,81,81,79,83,84,84,83,80,91,95,103,80,77,134,154,135,98,120,101,111,90,124,86,96,88,72,68,87,103,55,78,59,97,60,54,
+ 152,167,143,161,122,172,164,148,183,156,155,169,168,197,182,164,200,152,122,134,150,169,152,118,138,80,135,210,216,180,115,214,201,207,81,81,86,82,74,73,74,77,83,84,76,74,93,77,88,102,86,103,81,102,77,95,163,152,97,83,86,86,109,120,93,65,145,150,70,
+ 105,131,147,147,158,187,190,195,152,207,192,191,180,186,91,78,57,105,114,130,158,75,190,126,84,106,92,68,97,102,142,145,200,176,75,129,123,73,79,76,72,76,79,70,73,76,73,76,88,77,76,74,84,125,103,96,112,82,86,88,162,170,150,154,161,126,126,139,120,
+ 137,161,143,149,167,170,196,182,209,206,194,169,155,66,101,71,59,70,72,154,151,95,169,129,67,62,78,67,73,68,128,121,123,181,197,79,71,82,80,83,86,83,85,61,71,71,81,76,77,89,101,78,140,134,149,76,137,163,99,173,176,169,175,168,61,147,152,123,173,
+ 113,129,155,158,167,97,100,195,165,208,147,142,107,115,59,61,49,150,147,184,126,66,121,158,143,76,68,85,80,88,151,152,108,124,125,102,79,77,85,79,72,67,81,73,74,72,98,86,83,130,115,125,122,99,133,166,127,131,149,180,152,85,140,116,152,44,38,44,33,
+ 79,96,169,201,195,85,145,207,114,136,88,82,140,88,105,72,94,92,74,110,83,61,109,162,104,86,53,89,106,89,124,161,165,129,85,93,88,71,71,107,74,87,73,76,67,74,79,96,93,65,94,128,158,151,195,134,141,128,71,73,83,74,147,44,40,42,79,36,46,
+ 115,107,98,148,135,92,99,138,138,111,116,72,86,59,91,100,100,95,142,80,121,119,109,98,89,73,71,109,91,151,153,128,132,72,151,168,176,142,72,80,73,95,78,84,84,76,71,69,71,76,123,82,76,131,114,85,126,132,173,158,112,120,39,37,41,34,44,36,58,
+ 159,131,116,90,99,84,90,170,106,98,125,72,121,157,172,152,104,69,56,116,141,126,153,88,135,137,129,111,115,141,80,116,79,76,70,122,89,121,79,144,105,81,74,98,78,75,65,75,74,98,103,112,116,112,120,140,97,60,72,70,59,41,48,60,48,44,52,60,74,
+ 145,171,96,121,115,135,125,143,137,113,132,124,144,128,97,66,63,69,80,97,111,81,124,79,57,67,142,129,119,72,89,150,101,105,127,92,137,115,118,129,120,145,94,70,73,70,73,72,70,76,87,73,92,91,106,96,92,111,79,75,82,45,57,49,57,59,56,73,103,
+ 132,164,131,88,76,82,169,124,102,113,112,125,144,152,165,65,66,68,99,106,100,122,80,77,61,71,139,142,63,67,84,128,97,112,130,59,108,117,89,90,82,166,137,146,108,108,86,70,72,95,75,99,86,72,71,92,84,93,94,102,126,52,48,75,74,59,41,83,129,
+ 155,177,77,75,73,154,163,117,147,124,114,130,147,136,140,85,159,102,124,138,65,60,63,65,83,62,123,163,84,62,104,137,63,113,118,100,105,95,70,90,70,128,66,141,117,175,162,77,145,74,102,91,87,92,75,108,89,111,119,128,117,67,87,105,95,57,85,187,139,
+ 79,70,72,71,71,141,93,157,174,148,154,161,89,63,141,167,101,108,162,57,69,76,55,72,69,69,65,129,126,120,88,120,122,172,105,80,92,62,66,64,111,48,55,75,55,132,122,136,66,96,83,102,85,70,92,99,108,103,128,138,213,131,115,140,127,80,140,183,171,
+ 71,71,74,71,108,174,138,150,190,116,81,93,95,94,101,191,105,164,79,59,76,61,70,64,73,90,116,60,70,61,84,153,178,150,129,60,63,74,67,67,62,67,81,74,93,129,92,77,63,67,82,118,90,124,71,69,115,142,95,131,159,133,161,120,135,90,141,139,141,
+ 70,77,68,135,172,147,126,137,172,111,90,76,129,70,136,117,93,91,123,71,116,80,65,73,54,78,128,74,98,156,162,161,158,107,73,59,62,51,66,54,53,85,89,111,85,121,77,74,53,59,60,86,110,86,84,80,134,118,148,125,111,129,83,143,139,90,68,175,161,
+ 65,70,75,74,170,129,165,111,146,95,121,128,106,129,123,159,102,147,164,123,143,62,79,141,68,124,145,149,144,135,145,158,159,109,94,60,55,86,61,62,76,59,70,62,120,71,89,52,100,72,63,74,50,88,119,112,75,126,160,145,153,177,125,126,82,132,134,161,140,
+ 108,68,82,147,153,84,123,143,169,80,93,95,71,140,129,155,133,92,130,133,138,104,102,116,127,118,153,120,136,109,163,157,205,62,88,81,51,62,54,119,66,52,75,67,84,61,88,53,46,74,113,66,153,60,45,71,120,124,140,200,165,171,72,82,97,92,144,153,58,
+ 66,69,70,94,97,63,106,110,122,91,112,187,121,110,144,158,78,144,116,102,113,109,149,141,102,104,96,133,114,90,155,156,121,71,51,51,43,48,61,61,72,60,66,56,97,104,77,65,53,46,65,73,90,79,56,70,60,116,72,158,62,206,65,100,67,62,65,107,78,
+ 69,74,131,165,105,104,102,136,88,68,145,137,118,149,91,119,116,137,105,126,100,112,106,71,95,104,102,161,128,125,144,184,118,57,132,162,76,76,96,145,107,90,63,64,66,66,64,66,107,85,69,120,97,121,66,76,81,92,73,94,65,94,169,65,113,61,56,71,41,
+ 70,65,77,85,77,69,131,121,61,105,146,134,106,123,78,163,109,112,110,166,105,69,97,109,138,142,143,142,145,167,137,115,136,119,168,124,77,116,93,114,64,108,107,68,83,51,73,105,117,126,111,54,86,91,101,60,99,59,60,83,61,160,145,130,60,57,69,86,62,
+ 89,70,130,74,102,67,61,86,74,137,107,132,111,93,150,62,142,114,145,106,101,92,131,98,88,110,105,146,143,151,173,117,153,111,131,124,96,115,125,104,81,120,134,86,111,86,81,64,101,112,93,93,88,117,93,57,58,41,73,55,66,60,66,52,52,69,75,14,32,
+ 98,152,102,119,68,134,73,83,112,146,139,80,110,112,140,108,91,102,108,72,114,100,119,108,72,85,161,129,161,174,122,120,155,81,110,91,144,153,97,131,89,113,125,127,109,71,69,103,90,139,113,68,89,126,90,109,43,48,53,49,58,65,59,67,133,127,113,81,81,
+ 124,132,136,59,119,75,108,170,103,89,116,82,92,147,152,114,118,125,98,115,127,108,130,124,94,105,178,129,120,140,112,110,63,104,120,95,126,135,116,82,98,97,152,89,109,99,52,90,83,123,151,90,110,85,86,141,132,66,67,58,67,89,71,103,86,106,110,61,40,
+ 127,119,71,171,97,140,100,73,72,67,88,86,94,104,115,80,84,142,87,120,122,125,106,122,101,138,111,116,179,126,63,78,96,69,154,114,118,66,115,62,70,164,117,64,140,65,96,90,96,92,129,81,116,144,117,113,74,66,120,58,78,84,81,85,67,129,117,41,113,
+ 144,92,126,117,148,152,96,82,85,68,69,72,123,119,56,74,156,118,119,160,115,113,141,123,122,58,84,150,87,143,76,132,58,103,99,81,57,64,94,57,118,105,96,100,59,67,74,107,68,105,134,140,91,137,153,123,74,37,65,82,66,80,101,68,54,63,50,119,79,
+ 61,65,107,166,132,96,154,93,81,140,99,70,107,127,87,100,67,71,149,104,75,120,128,121,139,69,94,113,123,136,146,115,83,125,134,101,67,54,70,95,79,144,81,58,59,65,70,114,78,98,130,153,83,99,136,56,116,109,95,95,62,68,59,76,49,58,14,83,72,
+ 64,66,82,69,93,109,91,73,169,69,101,125,69,80,117,41,60,113,119,93,99,98,118,108,127,95,124,163,124,134,148,80,142,127,107,67,95,67,84,101,121,137,122,101,49,57,63,88,81,88,100,109,147,146,49,69,46,66,67,46,97,79,66,110,60,66,17,36,74,
+ 72,62,59,59,78,204,94,110,100,109,100,137,82,121,131,117,113,146,84,88,98,106,120,149,126,116,150,121,141,140,112,88,108,68,121,109,127,73,70,121,134,150,71,65,88,87,70,60,102,108,96,154,120,152,68,68,58,88,36,87,61,103,96,123,79,57,65,40,51,
+},
+{
+ 144,146,144,145,144,144,144,146,145,144,144,145,145,148,160,176,176,160,188,190,166,170,147,147,147,146,145,144,146,145,144,145,145,144,144,145,145,143,143,144,145,143,144,143,143,145,144,144,145,144,144,146,145,146,148,148,150,149,152,151,152,154,206,207,222,236,242,236,238,
+ 148,147,147,147,148,147,148,148,148,148,149,149,149,149,152,152,152,154,177,179,178,153,150,149,149,150,150,149,149,148,149,149,149,148,148,148,148,147,149,146,147,147,148,147,148,147,148,148,148,149,149,149,149,150,150,156,201,156,156,209,174,213,236,216,236,237,239,244,235,
+ 153,152,154,152,153,151,151,152,152,152,152,153,153,155,154,154,154,154,156,155,156,155,159,155,155,154,154,153,154,154,154,153,152,152,152,153,152,152,152,151,151,152,150,150,151,152,151,151,151,150,153,153,153,154,206,222,231,232,238,230,235,229,221,217,219,220,220,227,221,
+ 157,155,155,157,156,156,157,156,156,157,157,157,158,158,158,157,158,158,159,159,158,158,159,158,159,158,158,158,158,156,157,156,156,157,157,156,156,155,155,154,155,154,154,155,155,155,154,154,155,155,156,161,165,157,176,196,215,229,226,219,216,220,219,223,214,201,197,200,202,
+ 161,160,160,161,160,159,160,160,160,161,161,162,163,162,162,162,162,161,163,162,163,163,162,162,162,162,162,163,163,160,161,162,161,161,161,160,160,160,159,161,158,160,163,159,159,158,159,158,158,159,159,162,167,184,198,194,187,201,208,221,207,201,191,190,188,192,192,190,190,
+ 165,165,164,164,165,165,164,165,166,165,166,165,165,166,166,164,166,166,167,167,166,167,167,167,166,167,167,167,167,166,167,167,166,166,166,166,164,166,176,177,177,192,183,195,180,163,162,162,162,163,163,163,164,166,175,175,179,187,211,207,203,219,221,209,197,197,194,198,208,
+ 169,169,168,168,167,167,169,169,168,168,167,169,170,171,170,170,170,171,170,169,171,172,171,171,170,173,171,171,171,171,170,171,170,169,175,169,170,171,170,168,172,170,174,168,169,167,177,184,180,171,166,166,167,168,169,170,171,182,205,210,217,197,215,203,204,194,187,201,200,
+ 172,173,172,173,172,173,172,172,172,173,173,172,173,174,174,174,174,174,176,192,242,178,177,176,176,176,176,176,176,175,176,212,175,190,193,188,193,174,172,172,171,171,171,171,171,171,170,171,172,172,171,171,171,172,173,182,200,202,204,193,196,215,205,224,214,207,207,215,205,
+ 177,176,175,176,176,176,175,175,177,176,177,177,178,180,245,241,180,184,227,232,243,246,235,183,190,181,202,213,181,181,200,219,217,223,233,233,228,180,178,176,176,176,176,176,175,174,175,175,176,175,175,176,177,179,178,234,222,202,223,197,196,203,198,204,206,193,189,181,180,
+ 179,180,178,180,179,178,179,179,179,180,180,183,228,245,247,248,247,201,227,227,225,231,234,223,228,221,201,186,199,208,224,194,204,208,208,207,209,209,200,181,181,180,180,180,178,180,177,179,180,179,179,179,220,233,221,228,238,238,238,222,220,205,190,197,195,194,182,173,167,
+ 182,183,182,182,183,184,184,184,185,185,186,231,215,218,240,242,245,219,204,205,206,211,206,201,193,195,220,200,203,213,217,224,205,204,193,191,195,205,197,218,197,184,190,200,191,202,191,193,199,206,207,208,208,233,216,206,228,237,238,229,233,223,224,223,220,199,185,195,204,
+ 187,187,187,187,188,189,189,198,196,188,220,204,234,208,207,210,229,213,227,216,216,225,76,179,203,188,186,189,190,207,225,227,213,193,223,219,229,228,230,201,208,195,206,201,196,203,198,203,209,218,220,205,200,195,197,191,213,214,215,194,234,230,189,211,221,228,194,190,191,
+ 190,191,189,189,188,195,207,213,210,220,199,191,205,204,213,213,208,212,216,221,226,207,127,71,190,192,177,176,169,189,198,201,200,200,202,206,205,203,206,212,219,198,197,200,209,224,221,216,204,199,196,202,194,199,199,183,184,195,196,211,221,218,211,221,212,208,203,198,210,
+ 194,193,192,192,211,194,198,203,194,191,191,194,190,190,193,183,208,201,194,173,146,207,79,100,187,189,182,173,200,185,194,199,197,210,196,186,182,184,180,185,200,194,194,212,221,223,195,195,195,196,199,207,197,208,197,199,188,192,201,184,189,189,208,214,214,212,186,185,187,
+ 195,203,195,217,193,199,199,204,207,199,204,213,208,200,187,203,209,180,195,184,188,121,77,73,179,179,202,189,186,175,175,193,176,178,181,187,199,199,196,215,205,197,205,204,202,207,221,203,207,210,204,205,202,209,214,195,205,193,195,196,196,194,188,189,192,189,194,189,193,
+ 199,193,198,200,201,199,198,203,194,199,202,202,199,195,198,117,187,194,184,169,132,121,79,79,136,184,172,189,177,144,169,178,210,216,208,205,193,200,202,200,208,199,192,199,204,199,197,199,198,208,200,200,203,198,201,198,200,198,195,193,191,192,186,196,187,183,184,186,179,
+ 200,198,198,198,165,190,137,190,198,191,207,206,105,143,133,180,184,195,104,118,129,114,85,87,154,185,164,158,161,172,171,177,195,192,191,194,195,183,190,199,200,201,199,198,154,192,198,196,192,192,203,205,197,191,174,139,154,174,150,202,149,155,157,153,174,197,186,149,148,
+ 140,157,143,139,163,134,132,117,123,150,112,151,196,181,204,207,202,112,106,149,111,128,94,88,138,161,161,171,174,180,171,166,155,100,101,201,195,204,184,192,179,171,147,148,170,175,140,133,111,114,120,134,153,161,139,148,146,148,147,152,123,131,131,147,173,122,115,111,121,
+ 140,153,170,120,136,128,130,168,146,170,148,155,171,209,178,182,120,110,117,111,136,148,75,75,145,182,144,162,169,155,167,182,168,172,97,101,95,115,113,92,90,128,91,95,141,114,108,107,108,107,105,107,108,107,123,143,128,123,139,119,148,134,107,108,104,106,103,101,71,
+ 174,145,131,150,166,160,193,185,160,145,190,146,188,169,175,170,134,158,100,114,168,133,142,80,170,122,101,177,190,173,172,196,161,129,82,81,79,80,82,84,88,85,92,93,99,77,77,128,150,129,100,120,106,113,101,128,104,109,102,86,84,101,114,73,91,75,109,74,68,
+ 154,164,144,156,125,166,159,149,179,157,150,166,169,191,182,165,190,145,118,132,149,162,143,103,125,67,130,195,203,167,104,203,190,196,74,75,75,76,73,72,74,75,79,80,75,76,91,72,84,98,82,96,76,98,98,112,161,151,115,102,103,103,121,124,91,73,134,144,72,
+ 112,140,152,153,159,181,183,188,154,202,185,188,179,182,87,74,55,103,111,130,157,78,178,116,80,98,82,55,85,93,131,138,189,162,69,119,111,69,70,67,69,70,73,69,70,74,71,72,83,70,72,70,76,114,92,90,104,96,103,106,162,167,150,154,160,127,120,134,119,
+ 140,161,148,152,167,164,190,177,203,201,191,167,156,62,95,65,53,57,63,148,151,96,163,116,53,55,72,56,60,51,120,115,116,171,180,66,65,74,70,73,81,77,79,61,64,67,78,73,73,82,101,70,132,125,140,73,132,154,115,168,173,166,173,166,66,143,152,125,169,
+ 115,127,155,158,167,95,96,188,164,204,150,137,112,114,54,56,47,141,136,179,130,77,118,151,137,61,64,72,63,75,136,140,99,118,109,88,64,72,75,65,65,62,73,64,68,69,94,75,76,126,112,122,121,103,129,154,119,125,149,176,150,83,136,113,151,56,46,56,40,
+ 82,96,169,195,188,85,139,201,113,129,92,77,138,87,101,69,85,89,61,92,75,72,101,156,89,64,50,75,91,76,112,151,147,115,68,73,72,61,63,102,63,76,68,63,61,66,70,84,83,65,91,127,153,145,181,123,133,121,63,70,84,76,145,57,54,55,83,47,54,
+ 111,114,103,149,135,84,92,136,136,107,110,68,79,69,93,101,101,91,134,69,119,115,100,91,77,56,54,101,81,147,142,116,119,61,136,154,159,130,55,67,63,84,70,68,74,67,63,60,62,63,117,79,69,127,114,82,120,127,168,153,111,114,54,50,55,45,61,47,67,
+ 158,133,115,90,103,88,91,163,106,98,125,64,120,151,167,150,103,62,53,108,135,125,149,74,125,124,119,99,111,132,67,112,67,63,60,110,79,117,68,132,88,62,56,86,72,65,56,62,61,99,102,109,111,105,114,131,87,57,69,67,57,54,60,73,63,56,61,67,78,
+ 144,169,98,125,113,141,124,142,135,114,131,126,143,126,96,61,56,60,74,82,109,79,113,66,49,53,129,125,112,54,81,142,90,91,121,84,124,110,107,113,113,135,70,52,58,58,59,60,59,61,72,67,88,88,95,90,78,103,75,71,88,57,68,62,69,69,69,79,102,
+ 136,159,131,99,77,82,167,121,94,114,114,124,142,150,159,61,59,59,94,102,93,121,60,52,46,46,131,138,53,52,62,124,97,105,126,54,102,105,79,78,73,154,124,134,95,91,65,54,56,85,64,96,74,67,49,80,85,91,89,103,124,65,62,85,84,72,52,81,127,
+ 153,173,75,73,72,154,164,120,146,121,113,128,144,133,128,77,152,91,122,135,52,44,43,45,64,51,114,158,73,48,96,130,58,106,117,92,103,84,53,78,53,112,52,132,103,161,152,58,130,67,94,91,82,83,72,98,78,107,115,129,115,79,93,109,98,67,88,178,133,
+ 80,70,71,74,71,140,96,152,170,145,153,158,80,55,130,160,97,97,158,46,51,59,44,48,48,49,53,122,120,107,72,108,118,163,105,74,89,46,41,45,101,40,38,48,47,125,109,127,47,81,74,100,84,62,94,95,100,94,123,137,202,132,118,139,128,76,138,177,165,
+ 71,70,74,75,111,173,130,147,184,108,77,91,91,85,100,185,102,151,62,47,58,42,52,46,53,68,109,50,52,47,71,140,174,144,125,46,51,58,43,44,46,52,60,53,89,122,78,54,43,46,65,104,74,116,57,55,110,140,97,129,154,132,158,121,135,95,139,138,132,
+ 71,79,70,133,168,145,124,137,165,110,87,70,128,64,128,106,85,83,110,61,104,66,45,53,45,65,122,62,93,152,155,153,152,105,62,42,49,39,50,38,46,82,86,106,74,115,62,59,38,40,41,61,101,76,63,68,129,104,144,120,118,124,77,141,139,91,67,172,156,
+ 67,68,72,73,170,129,163,114,143,93,124,125,105,128,123,149,103,137,152,115,139,51,70,136,56,113,138,144,138,130,139,152,151,99,84,54,46,75,43,49,57,39,52,52,112,55,73,40,83,51,52,60,37,77,105,97,56,120,155,141,145,172,126,124,83,131,133,159,133,
+ 109,70,82,147,155,80,123,145,168,76,96,99,66,140,129,152,132,85,126,130,136,100,90,111,121,114,148,113,127,106,160,152,198,53,79,67,35,43,40,109,51,36,59,48,84,55,85,38,36,59,104,44,139,48,38,54,114,116,138,194,160,166,57,66,98,88,140,149,47,
+ 66,65,72,93,94,61,106,114,123,90,113,182,119,111,141,154,75,140,113,101,109,104,143,139,101,102,88,129,105,83,152,150,113,60,40,40,37,35,45,40,71,44,47,47,96,103,52,42,45,38,53,61,81,58,42,47,45,111,50,153,50,201,52,88,50,64,52,94,39,
+ 65,70,128,162,101,103,108,135,93,60,138,137,117,145,92,116,115,134,102,123,95,97,92,61,85,99,95,158,121,114,139,178,106,46,118,150,63,66,84,139,96,84,49,43,48,49,41,44,87,72,51,106,93,111,54,65,68,74,62,80,46,94,157,56,110,50,43,40,18,
+ 68,64,75,81,74,60,133,120,56,106,147,131,108,123,70,163,101,108,107,160,94,56,87,101,133,136,139,137,141,165,136,110,132,112,159,120,60,102,90,109,55,103,101,61,84,43,63,100,107,122,103,57,82,87,94,47,87,49,53,76,60,151,142,127,47,43,62,46,35,
+ 87,62,127,69,101,60,58,87,67,140,108,131,112,90,150,56,140,110,138,95,98,84,121,92,88,105,95,140,136,148,168,114,149,107,125,121,90,110,122,103,76,109,123,67,100,75,65,46,100,106,89,91,88,113,92,49,46,49,66,44,50,46,47,39,42,48,31,6,14,
+ 101,153,109,119,59,130,65,76,112,146,136,77,102,113,143,107,93,100,105,58,112,91,108,96,65,83,155,120,155,168,120,117,147,72,105,90,139,149,93,123,84,109,108,123,106,54,50,96,80,133,106,68,83,123,78,97,41,44,49,43,50,50,43,47,121,124,99,56,39,
+ 123,133,137,56,119,72,105,163,107,86,109,74,91,147,153,114,118,121,98,112,126,99,125,118,94,97,167,115,118,135,110,106,52,102,115,92,122,134,110,82,87,81,148,78,108,96,40,78,75,106,143,80,107,86,83,131,125,71,65,48,59,77,67,92,76,99,107,27,26,
+ 126,123,66,172,98,141,98,72,60,61,78,82,94,107,117,71,88,142,75,117,120,124,102,120,103,136,102,110,176,120,50,74,90,57,149,107,114,56,111,43,64,158,111,56,132,61,90,82,90,89,122,71,110,137,112,99,69,69,115,45,71,79,80,73,48,123,115,24,83,
+ 138,98,128,121,148,153,102,81,77,62,61,65,121,121,51,64,146,116,120,156,114,110,137,117,119,51,66,146,79,137,66,118,48,97,94,66,44,48,88,44,106,103,91,96,45,54,56,98,50,105,128,138,82,131,150,117,73,43,70,80,66,67,100,47,46,48,23,111,45,
+ 59,60,102,164,133,95,150,100,85,140,99,62,108,125,88,103,63,58,148,102,67,118,124,119,137,60,83,110,121,127,137,107,82,123,124,95,55,45,54,90,65,134,66,42,46,51,58,101,64,94,129,145,77,94,129,52,104,109,93,89,51,50,49,63,42,42,7,37,53,
+ 59,59,76,71,96,113,89,71,170,66,103,123,71,86,117,49,50,108,121,93,100,97,117,106,126,97,121,158,122,132,143,72,132,117,99,57,88,58,75,98,114,134,116,94,38,42,42,64,71,77,95,109,141,132,40,72,52,71,63,49,93,79,53,100,42,61,7,16,32,
+ 60,56,58,54,70,201,97,116,107,114,103,139,80,123,133,118,110,142,70,87,97,103,118,146,121,108,143,117,136,135,110,86,110,64,108,96,121,66,57,116,123,148,58,53,76,73,57,46,101,103,95,151,114,143,59,74,60,89,38,88,66,99,96,121,65,44,52,20,28,
+},
+};
+
+using namespace boost::gil;
+extern rgb8c_planar_view_t sample_view;
+rgb8c_planar_view_t sample_view = planar_rgb_view(69,46,halfdome[0],halfdome[1],halfdome[2],69);