File: test_sort_by_transform.cpp

package info (click to toggle)
boost1.90 1.90.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 593,120 kB
  • sloc: cpp: 4,190,908; xml: 196,648; python: 34,618; ansic: 23,145; asm: 5,468; sh: 3,774; makefile: 1,161; perl: 1,020; sql: 728; ruby: 676; yacc: 478; java: 77; lisp: 24; csh: 6
file content (110 lines) | stat: -rw-r--r-- 3,262 bytes parent folder | download | duplicates (18)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
//---------------------------------------------------------------------------//
// Copyright (c) 2013 Kyle Lutz <kyle.r.lutz@gmail.com>
//
// 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
//
// See http://boostorg.github.com/compute for more information.
//---------------------------------------------------------------------------//

#define BOOST_TEST_MODULE TestSortByTransform
#include <boost/test/unit_test.hpp>

#include <boost/compute/system.hpp>
#include <boost/compute/algorithm/copy_n.hpp>
#include <boost/compute/algorithm/is_sorted.hpp>
#include <boost/compute/container/vector.hpp>
#include <boost/compute/experimental/sort_by_transform.hpp>

#include "check_macros.hpp"
#include "context_setup.hpp"

namespace compute = boost::compute;

BOOST_AUTO_TEST_CASE(sort_int_by_abs)
{
    int data[] = { 1, -2, 4, -3, 0, 5, -8, -9 };
    compute::vector<int> vector(data, data + 8, queue);

    compute::experimental::sort_by_transform(
        vector.begin(),
        vector.end(),
        compute::abs<int>(),
        compute::less<int>(),
        queue
    );

    CHECK_RANGE_EQUAL(int, 8, vector, (0, 1, -2, -3, 4, 5, -8, -9));
}

BOOST_AUTO_TEST_CASE(sort_vectors_by_length)
{
    using compute::float4_;

    float data[] = {
        1.0f, 0.0f, 0.0f, 0.0f,
        0.0f, 1.0f, 1.0f, 0.0f,
        3.0f, 2.0f, 1.0f, 0.0f,
        0.0f, 0.0f, 0.5f, 0.0f
    };

    compute::vector<float4_> vector(4, context);
    compute::copy_n(
        reinterpret_cast<float4_ *>(data), 4, vector.begin(), queue
    );

    compute::experimental::sort_by_transform(
        vector.begin(),
        vector.end(),
        compute::length<float4_>(),
        compute::less<float>(),
        queue
    );

    std::vector<float4_> host_vector(4);
    compute::copy(
        vector.begin(), vector.end(), host_vector.begin(), queue
    );
    BOOST_CHECK_EQUAL(host_vector[0], float4_(0.0f, 0.0f, 0.5f, 0.0f));
    BOOST_CHECK_EQUAL(host_vector[1], float4_(1.0f, 0.0f, 0.0f, 0.0f));
    BOOST_CHECK_EQUAL(host_vector[2], float4_(0.0f, 1.0f, 1.0f, 0.0f));
    BOOST_CHECK_EQUAL(host_vector[3], float4_(3.0f, 2.0f, 1.0f, 0.0f));
}

BOOST_AUTO_TEST_CASE(sort_vectors_by_component)
{
    using compute::float4_;

    float data[] = {
        1.0f, 2.0f, 3.0f, 0.0f,
        9.0f, 8.0f, 7.0f, 0.0f,
        4.0f, 5.0f, 6.0f, 0.0f,
        0.0f, 0.0f, 0.0f, 0.0f
    };

    compute::vector<float4_> vector(4, context);
    compute::copy_n(
        reinterpret_cast<float4_ *>(data), 4, vector.begin(), queue
    );

    // sort by y-component
    compute::experimental::sort_by_transform(
        vector.begin(),
        vector.end(),
        compute::get<1>(),
        compute::less<float>(),
        queue
    );

    std::vector<float4_> host_vector(4);
    compute::copy(
        vector.begin(), vector.end(), host_vector.begin(), queue
    );
    BOOST_CHECK_EQUAL(host_vector[0], float4_(0.0f, 0.0f, 0.0f, 0.0f));
    BOOST_CHECK_EQUAL(host_vector[1], float4_(1.0f, 2.0f, 3.0f, 0.0f));
    BOOST_CHECK_EQUAL(host_vector[2], float4_(4.0f, 5.0f, 6.0f, 0.0f));
    BOOST_CHECK_EQUAL(host_vector[3], float4_(9.0f, 8.0f, 7.0f, 0.0f));
}

BOOST_AUTO_TEST_SUITE_END()