Spaces:
Runtime error
Runtime error
THRUST_DISABLE_MSVC_POSSIBLE_LOSS_OF_DATA_WARNING_BEGIN | |
void TestCountingIteratorCopyConstructor(void) | |
{ | |
thrust::counting_iterator<int> iter0(100); | |
thrust::counting_iterator<int> iter1(iter0); | |
ASSERT_EQUAL_QUIET(iter0, iter1); | |
ASSERT_EQUAL(*iter0, *iter1); | |
// construct from related space | |
thrust::counting_iterator<int, thrust::host_system_tag> h_iter = iter0; | |
ASSERT_EQUAL(*iter0, *h_iter); | |
thrust::counting_iterator<int, thrust::device_system_tag> d_iter = iter0; | |
ASSERT_EQUAL(*iter0, *d_iter); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorCopyConstructor); | |
void TestCountingIteratorIncrement(void) | |
{ | |
thrust::counting_iterator<int> iter(0); | |
ASSERT_EQUAL(*iter, 0); | |
iter++; | |
ASSERT_EQUAL(*iter, 1); | |
iter++; | |
iter++; | |
ASSERT_EQUAL(*iter, 3); | |
iter += 5; | |
ASSERT_EQUAL(*iter, 8); | |
iter -= 10; | |
ASSERT_EQUAL(*iter, -2); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorIncrement); | |
void TestCountingIteratorComparison(void) | |
{ | |
thrust::counting_iterator<int> iter1(0); | |
thrust::counting_iterator<int> iter2(0); | |
ASSERT_EQUAL(iter1 - iter2, 0); | |
ASSERT_EQUAL(iter1 == iter2, true); | |
iter1++; | |
ASSERT_EQUAL(iter1 - iter2, 1); | |
ASSERT_EQUAL(iter1 == iter2, false); | |
iter2++; | |
ASSERT_EQUAL(iter1 - iter2, 0); | |
ASSERT_EQUAL(iter1 == iter2, true); | |
iter1 += 100; | |
iter2 += 100; | |
ASSERT_EQUAL(iter1 - iter2, 0); | |
ASSERT_EQUAL(iter1 == iter2, true); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorComparison); | |
void TestCountingIteratorFloatComparison(void) | |
{ | |
thrust::counting_iterator<float> iter1(0); | |
thrust::counting_iterator<float> iter2(0); | |
ASSERT_EQUAL(iter1 - iter2, 0); | |
ASSERT_EQUAL(iter1 == iter2, true); | |
ASSERT_EQUAL(iter1 < iter2, false); | |
ASSERT_EQUAL(iter2 < iter1, false); | |
iter1++; | |
ASSERT_EQUAL(iter1 - iter2, 1); | |
ASSERT_EQUAL(iter1 == iter2, false); | |
ASSERT_EQUAL(iter2 < iter1, true); | |
ASSERT_EQUAL(iter1 < iter2, false); | |
iter2++; | |
ASSERT_EQUAL(iter1 - iter2, 0); | |
ASSERT_EQUAL(iter1 == iter2, true); | |
ASSERT_EQUAL(iter1 < iter2, false); | |
ASSERT_EQUAL(iter2 < iter1, false); | |
iter1 += 100; | |
iter2 += 100; | |
ASSERT_EQUAL(iter1 - iter2, 0); | |
ASSERT_EQUAL(iter1 == iter2, true); | |
ASSERT_EQUAL(iter1 < iter2, false); | |
ASSERT_EQUAL(iter2 < iter1, false); | |
thrust::counting_iterator<float> iter3(0); | |
thrust::counting_iterator<float> iter4(0.5); | |
ASSERT_EQUAL(iter3 - iter4, 0); | |
ASSERT_EQUAL(iter3 == iter4, true); | |
ASSERT_EQUAL(iter3 < iter4, false); | |
ASSERT_EQUAL(iter4 < iter3, false); | |
iter3++; // iter3 = 1.0, iter4 = 0.5 | |
ASSERT_EQUAL(iter3 - iter4, 0); | |
ASSERT_EQUAL(iter3 == iter4, true); | |
ASSERT_EQUAL(iter3 < iter4, false); | |
ASSERT_EQUAL(iter4 < iter3, false); | |
iter4++; // iter3 = 1.0, iter4 = 1.5 | |
ASSERT_EQUAL(iter3 - iter4, 0); | |
ASSERT_EQUAL(iter3 == iter4, true); | |
ASSERT_EQUAL(iter3 < iter4, false); | |
ASSERT_EQUAL(iter4 < iter3, false); | |
iter4++; // iter3 = 1.0, iter4 = 2.5 | |
ASSERT_EQUAL(iter3 - iter4, -1); | |
ASSERT_EQUAL(iter4 - iter3, 1); | |
ASSERT_EQUAL(iter3 == iter4, false); | |
ASSERT_EQUAL(iter3 < iter4, true); | |
ASSERT_EQUAL(iter4 < iter3, false); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorFloatComparison); | |
void TestCountingIteratorDistance(void) | |
{ | |
thrust::counting_iterator<int> iter1(0); | |
thrust::counting_iterator<int> iter2(5); | |
ASSERT_EQUAL(thrust::distance(iter1, iter2), 5); | |
iter1++; | |
ASSERT_EQUAL(thrust::distance(iter1, iter2), 4); | |
iter2 += 100; | |
ASSERT_EQUAL(thrust::distance(iter1, iter2), 104); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorDistance); | |
void TestCountingIteratorUnsignedType(void) | |
{ | |
thrust::counting_iterator<unsigned int> iter0(0); | |
thrust::counting_iterator<unsigned int> iter1(5); | |
ASSERT_EQUAL(iter1 - iter0, 5); | |
ASSERT_EQUAL(iter0 - iter1, -5); | |
ASSERT_EQUAL(iter0 != iter1, true); | |
ASSERT_EQUAL(iter0 < iter1, true); | |
ASSERT_EQUAL(iter1 < iter0, false); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorUnsignedType); | |
void TestCountingIteratorLowerBound(void) | |
{ | |
size_t n = 10000; | |
const size_t M = 100; | |
thrust::host_vector<unsigned int> h_data = unittest::random_integers<unsigned int>(n); | |
for(unsigned int i = 0; i < n; ++i) | |
h_data[i] %= M; | |
thrust::sort(h_data.begin(), h_data.end()); | |
thrust::device_vector<unsigned int> d_data = h_data; | |
thrust::counting_iterator<unsigned int> search_begin(0); | |
thrust::counting_iterator<unsigned int> search_end(M); | |
thrust::host_vector<unsigned int> h_result(M); | |
thrust::device_vector<unsigned int> d_result(M); | |
thrust::lower_bound(h_data.begin(), h_data.end(), search_begin, search_end, h_result.begin()); | |
thrust::lower_bound(d_data.begin(), d_data.end(), search_begin, search_end, d_result.begin()); | |
ASSERT_EQUAL(h_result, d_result); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorLowerBound); | |
void TestCountingIteratorDifference(void) | |
{ | |
typedef thrust::counting_iterator<thrust::detail::uint64_t> Iterator; | |
typedef thrust::iterator_difference<Iterator>::type Difference; | |
Difference diff = std::numeric_limits<thrust::detail::uint32_t>::max() + 1; | |
Iterator first(0); | |
Iterator last = first + diff; | |
ASSERT_EQUAL(diff, last - first); | |
} | |
DECLARE_UNITTEST(TestCountingIteratorDifference); | |
THRUST_DISABLE_MSVC_POSSIBLE_LOSS_OF_DATA_WARNING_END | |