LIVE / thrust /testing /counting_iterator.cu
Xu Ma
update
1c3c0d9
#include <unittest/unittest.h>
#include <thrust/iterator/counting_iterator.h>
#include <thrust/sort.h>
#include <thrust/binary_search.h>
#include <thrust/distance.h>
#include <thrust/detail/cstdint.h>
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