-
Notifications
You must be signed in to change notification settings - Fork 107
/
Copy pathshuffle_weighted_test.cpp
79 lines (61 loc) · 2.09 KB
/
shuffle_weighted_test.cpp
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
/*
Copyright (c) Alexander Zaitsev <[email protected]>, 2017
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://www.boost.org/ for latest version.
*/
#define BOOST_TEST_DYN_LINK
#define BOOST_TEST_MAIN
#include <vector>
#include <boost/algorithm/shuffle_weighted.hpp>
#include <boost/random/mersenne_twister.hpp>
#include <boost/test/unit_test.hpp>
namespace ba = boost::algorithm;
namespace br = boost::random;
void test_shuffle_weighted()
{
{
// Empty case
br::mt19937_64 d;
std::vector<int> vec, weights;
ba::shuffle_weighted(vec, weights, d);
BOOST_CHECK(vec.empty () && weights.empty());
}
{
// One element case
br::mt19937_64 d;
std::vector<int> vec, weights;
vec.push_back(1);
weights.push_back(1);
std::vector<int> new_vec = vec, new_weights = weights;
ba::shuffle_weighted(new_vec, new_weights, d);
BOOST_CHECK(vec == new_vec && weights == new_weights);
}
{
// Two element case
br::mt19937_64 d;
std::vector<int> vec, rev_vec, weights;
vec.push_back(1); vec.push_back(2);
rev_vec.push_back(2); rev_vec.push_back(1);
weights = vec;
std::vector<int> new_vec = vec, new_weights = weights;
ba::shuffle_weighted(new_vec, new_weights, d);
BOOST_CHECK(vec == new_vec || rev_vec == new_vec);
}
{
// Two element case, iterator interface
br::mt19937_64 d;
std::vector<int> vec, rev_vec, weights;
vec.push_back(1); vec.push_back(2);
rev_vec.push_back(2); rev_vec.push_back(1);
weights = vec;
std::vector<int> new_vec = vec, new_weights = weights;
ba::shuffle_weighted(new_vec.begin(), new_vec.end(), new_weights.begin(), new_weights.end(), d);
BOOST_CHECK(vec == new_vec || rev_vec == new_vec);
}
}
BOOST_AUTO_TEST_CASE(test_main)
{
test_shuffle_weighted();
}