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