LIVE / thrust /testing /adjacent_difference.cu
Xu Ma
update
1c3c0d9
#include <unittest/unittest.h>
#include <thrust/adjacent_difference.h>
#include <thrust/iterator/discard_iterator.h>
#include <thrust/iterator/retag.h>
#include <thrust/device_malloc.h>
#include <thrust/device_free.h>
template <class Vector>
void TestAdjacentDifferenceSimple(void)
{
typedef typename Vector::value_type T;
Vector input(3);
Vector output(3);
input[0] = 1; input[1] = 4; input[2] = 6;
typename Vector::iterator result;
result = thrust::adjacent_difference(input.begin(), input.end(), output.begin());
ASSERT_EQUAL(result - output.begin(), 3);
ASSERT_EQUAL(output[0], T(1));
ASSERT_EQUAL(output[1], T(3));
ASSERT_EQUAL(output[2], T(2));
result = thrust::adjacent_difference(input.begin(), input.end(), output.begin(), thrust::plus<T>());
ASSERT_EQUAL(result - output.begin(), 3);
ASSERT_EQUAL(output[0], T( 1));
ASSERT_EQUAL(output[1], T( 5));
ASSERT_EQUAL(output[2], T(10));
// test in-place operation, result and first are permitted to be the same
result = thrust::adjacent_difference(input.begin(), input.end(), input.begin());
ASSERT_EQUAL(result - input.begin(), 3);
ASSERT_EQUAL(input[0], T(1));
ASSERT_EQUAL(input[1], T(3));
ASSERT_EQUAL(input[2], T(2));
}
DECLARE_VECTOR_UNITTEST(TestAdjacentDifferenceSimple);
template <typename T>
void TestAdjacentDifference(const size_t n)
{
thrust::host_vector<T> h_input = unittest::random_samples<T>(n);
thrust::device_vector<T> d_input = h_input;
thrust::host_vector<T> h_output(n);
thrust::device_vector<T> d_output(n);
typename thrust::host_vector<T>::iterator h_result;
typename thrust::device_vector<T>::iterator d_result;
h_result = thrust::adjacent_difference(h_input.begin(), h_input.end(), h_output.begin());
d_result = thrust::adjacent_difference(d_input.begin(), d_input.end(), d_output.begin());
ASSERT_EQUAL(std::size_t(h_result - h_output.begin()), n);
ASSERT_EQUAL(std::size_t(d_result - d_output.begin()), n);
ASSERT_EQUAL(h_output, d_output);
h_result = thrust::adjacent_difference(h_input.begin(), h_input.end(), h_output.begin(), thrust::plus<T>());
d_result = thrust::adjacent_difference(d_input.begin(), d_input.end(), d_output.begin(), thrust::plus<T>());
ASSERT_EQUAL(std::size_t(h_result - h_output.begin()), n);
ASSERT_EQUAL(std::size_t(d_result - d_output.begin()), n);
ASSERT_EQUAL(h_output, d_output);
// in-place operation
h_result = thrust::adjacent_difference(h_input.begin(), h_input.end(), h_input.begin(), thrust::plus<T>());
d_result = thrust::adjacent_difference(d_input.begin(), d_input.end(), d_input.begin(), thrust::plus<T>());
ASSERT_EQUAL(std::size_t(h_result - h_input.begin()), n);
ASSERT_EQUAL(std::size_t(d_result - d_input.begin()), n);
ASSERT_EQUAL(h_input, h_output); //computed previously
ASSERT_EQUAL(d_input, d_output); //computed previously
}
DECLARE_VARIABLE_UNITTEST(TestAdjacentDifference);
template<typename T>
void TestAdjacentDifferenceInPlaceWithRelatedIteratorTypes(const size_t n)
{
thrust::host_vector<T> h_input = unittest::random_samples<T>(n);
thrust::device_vector<T> d_input = h_input;
thrust::host_vector<T> h_output(n);
thrust::device_vector<T> d_output(n);
typename thrust::host_vector<T>::iterator h_result;
typename thrust::device_vector<T>::iterator d_result;
h_result = thrust::adjacent_difference(h_input.begin(), h_input.end(), h_output.begin(), thrust::plus<T>());
d_result = thrust::adjacent_difference(d_input.begin(), d_input.end(), d_output.begin(), thrust::plus<T>());
// in-place operation with different iterator types
h_result = thrust::adjacent_difference(h_input.cbegin(), h_input.cend(), h_input.begin(), thrust::plus<T>());
d_result = thrust::adjacent_difference(d_input.cbegin(), d_input.cend(), d_input.begin(), thrust::plus<T>());
ASSERT_EQUAL(std::size_t(h_result - h_input.begin()), n);
ASSERT_EQUAL(std::size_t(d_result - d_input.begin()), n);
ASSERT_EQUAL(h_output, h_input); // reference computed previously
ASSERT_EQUAL(d_output, d_input); // reference computed previously
}
DECLARE_VARIABLE_UNITTEST(TestAdjacentDifferenceInPlaceWithRelatedIteratorTypes);
template <typename T>
void TestAdjacentDifferenceDiscardIterator(const size_t n)
{
thrust::host_vector<T> h_input = unittest::random_samples<T>(n);
thrust::device_vector<T> d_input = h_input;
thrust::discard_iterator<> h_result =
thrust::adjacent_difference(h_input.begin(), h_input.end(), thrust::make_discard_iterator());
thrust::discard_iterator<> d_result =
thrust::adjacent_difference(d_input.begin(), d_input.end(), thrust::make_discard_iterator());
thrust::discard_iterator<> reference(n);
ASSERT_EQUAL_QUIET(reference, h_result);
ASSERT_EQUAL_QUIET(reference, d_result);
}
DECLARE_VARIABLE_UNITTEST(TestAdjacentDifferenceDiscardIterator);
template<typename InputIterator, typename OutputIterator>
OutputIterator adjacent_difference(my_system &system, InputIterator, InputIterator, OutputIterator result)
{
system.validate_dispatch();
return result;
}
void TestAdjacentDifferenceDispatchExplicit()
{
thrust::device_vector<int> d_input(1);
my_system sys(0);
thrust::adjacent_difference(sys,
d_input.begin(),
d_input.end(),
d_input.begin());
ASSERT_EQUAL(true, sys.is_valid());
}
DECLARE_UNITTEST(TestAdjacentDifferenceDispatchExplicit);
template<typename InputIterator, typename OutputIterator>
OutputIterator adjacent_difference(my_tag, InputIterator, InputIterator, OutputIterator result)
{
*result = 13;
return result;
}
void TestAdjacentDifferenceDispatchImplicit()
{
thrust::device_vector<int> d_input(1);
thrust::adjacent_difference(thrust::retag<my_tag>(d_input.begin()),
thrust::retag<my_tag>(d_input.end()),
thrust::retag<my_tag>(d_input.begin()));
ASSERT_EQUAL(13, d_input.front());
}
DECLARE_UNITTEST(TestAdjacentDifferenceDispatchImplicit);