#include #include #include #include #include template void tabulate(my_system &system, ForwardIterator, ForwardIterator, UnaryOperation) { system.validate_dispatch(); } void TestTabulateDispatchExplicit() { thrust::device_vector vec(1); my_system sys(0); thrust::tabulate(sys, vec.begin(), vec.end(), thrust::identity()); ASSERT_EQUAL(true, sys.is_valid()); } DECLARE_UNITTEST(TestTabulateDispatchExplicit); template void tabulate(my_tag, ForwardIterator first, ForwardIterator, UnaryOperation) { *first = 13; } void TestTabulateDispatchImplicit() { thrust::device_vector vec(1); thrust::tabulate(thrust::retag(vec.begin()), thrust::retag(vec.end()), thrust::identity()); ASSERT_EQUAL(13, vec.front()); } DECLARE_UNITTEST(TestTabulateDispatchImplicit); template void TestTabulateSimple(void) { using namespace thrust::placeholders; typedef typename Vector::value_type T; Vector v(5); thrust::tabulate(v.begin(), v.end(), thrust::identity()); ASSERT_EQUAL(v[0], 0); ASSERT_EQUAL(v[1], 1); ASSERT_EQUAL(v[2], 2); ASSERT_EQUAL(v[3], 3); ASSERT_EQUAL(v[4], 4); thrust::tabulate(v.begin(), v.end(), -_1); ASSERT_EQUAL(v[0], 0); ASSERT_EQUAL(v[1], -1); ASSERT_EQUAL(v[2], -2); ASSERT_EQUAL(v[3], -3); ASSERT_EQUAL(v[4], -4); thrust::tabulate(v.begin(), v.end(), _1 * _1 * _1); ASSERT_EQUAL(v[0], 0); ASSERT_EQUAL(v[1], 1); ASSERT_EQUAL(v[2], 8); ASSERT_EQUAL(v[3], 27); ASSERT_EQUAL(v[4], 64); } DECLARE_VECTOR_UNITTEST(TestTabulateSimple); template void TestTabulate(size_t n) { using namespace thrust::placeholders; thrust::host_vector h_data(n); thrust::device_vector d_data(n); thrust::tabulate(h_data.begin(), h_data.end(), _1 * _1 + 13); thrust::tabulate(d_data.begin(), d_data.end(), _1 * _1 + 13); ASSERT_EQUAL(h_data, d_data); thrust::tabulate(h_data.begin(), h_data.end(), (_1 - 7) * _1); thrust::tabulate(d_data.begin(), d_data.end(), (_1 - 7) * _1); ASSERT_EQUAL(h_data, d_data); } DECLARE_VARIABLE_UNITTEST(TestTabulate); template void TestTabulateToDiscardIterator(size_t n) { thrust::tabulate(thrust::discard_iterator(), thrust::discard_iterator(n), thrust::identity()); // nothing to check -- just make sure it compiles } DECLARE_VARIABLE_UNITTEST(TestTabulateToDiscardIterator);