• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //
2 // Copyright 2013 Krzysztof Czainski
3 // Copyright 2020 Mateusz Loskot <mateusz at loskot dot net>
4 //
5 // Distributed under the Boost Software License, Version 1.0
6 // See accompanying file LICENSE_1_0.txt or copy at
7 // http://www.boost.org/LICENSE_1_0.txt
8 //
9 #include <boost/gil.hpp>
10 #include <boost/gil/extension/numeric/resample.hpp>
11 #include <boost/gil/extension/numeric/sampler.hpp>
12 
13 #include <boost/core/lightweight_test.hpp>
14 
15 #include <cmath>
16 
17 #include "test_utility_output_stream.hpp"
18 
19 namespace gil = boost::gil;
20 
21 // FIXME: Remove when https://github.com/boostorg/core/issues/38 happens
22 #define BOOST_GIL_TEST_IS_CLOSE(a, b, epsilon) BOOST_TEST_LT(std::fabs((a) - (b)), (epsilon))
23 
test_plus()24 void test_plus()
25 {
26     gil::rgb8_pixel_t a(10, 20, 30);
27     gil::bgr8_pixel_t b(30, 20, 10);
28 
29     gil::pixel_plus_t<gil::rgb8_pixel_t, gil::bgr8_pixel_t, gil::rgb8_pixel_t> op;
30     gil::rgb8_pixel_t c = op(a, b);
31 
32     BOOST_TEST_EQ(get_color(c, gil::red_t()), 20);
33     BOOST_TEST_EQ(get_color(c, gil::green_t()), 40);
34     BOOST_TEST_EQ(get_color(c, gil::blue_t()), 60);
35 
36     gil::pixel_plus_t<gil::rgb8_pixel_t, gil::bgr8_pixel_t, gil::bgr8_pixel_t> op2;
37     gil::bgr8_pixel_t d = op2(a, b);
38 
39     BOOST_TEST_EQ(get_color(d, gil::red_t()), 20);
40     BOOST_TEST_EQ(get_color(d, gil::green_t()), 40);
41     BOOST_TEST_EQ(get_color(d, gil::blue_t()), 60);
42 }
43 
test_multiply()44 void test_multiply()
45 {
46     gil::rgb32f_pixel_t a(1.f, 2.f, 3.f);
47     gil::bgr32f_pixel_t b(2.f, 2.f, 2.f);
48 
49     gil::pixel_multiply_t<
50         gil::rgb32f_pixel_t, gil::bgr32f_pixel_t, gil::rgb32f_pixel_t>
51         op;
52     gil::rgb32f_pixel_t c = op(a, b);
53 
54     float epsilon = 1e-6f;
55     BOOST_GIL_TEST_IS_CLOSE(get_color(c, gil::red_t()), 2.f, epsilon);
56     BOOST_GIL_TEST_IS_CLOSE(get_color(c, gil::green_t()), 4.f, epsilon);
57     BOOST_GIL_TEST_IS_CLOSE(get_color(c, gil::blue_t()), 6.f, epsilon);
58 }
59 
test_divide()60 void test_divide()
61 {
62     // integer
63     {
64         gil::rgb8_pixel_t a(10, 20, 30);
65         gil::bgr8_pixel_t b(2, 2, 2);
66 
67         gil::pixel_divide_t<gil::rgb8_pixel_t, gil::bgr8_pixel_t, gil::rgb8_pixel_t> op;
68         gil::rgb32f_pixel_t c = op(a, b);
69 
70         BOOST_TEST_EQ(get_color(c, gil::red_t()), 5);
71         BOOST_TEST_EQ(get_color(c, gil::green_t()), 10);
72         BOOST_TEST_EQ(get_color(c, gil::blue_t()), 15);
73     }
74 
75     // float
76     {
77         gil::rgb32f_pixel_t a(1.f, 2.f, 3.f);
78         gil::bgr32f_pixel_t b(2.f, 2.f, 2.f);
79 
80         gil::pixel_divide_t<gil::rgb32f_pixel_t, gil::bgr32f_pixel_t, gil::rgb32f_pixel_t> op;
81         gil::rgb32f_pixel_t c = op(a, b);
82 
83         float epsilon = 1e-6f;
84         BOOST_GIL_TEST_IS_CLOSE(get_color(c, gil::red_t()), 0.5f, epsilon);
85         BOOST_GIL_TEST_IS_CLOSE(get_color(c, gil::green_t()), 1.f, epsilon);
86         BOOST_GIL_TEST_IS_CLOSE(get_color(c, gil::blue_t()), 1.5f, epsilon);
87     }
88 }
89 
main()90 int main()
91 {
92     test_plus();
93     test_multiply();
94     test_divide();
95 
96     return ::boost::report_errors();
97 }
98