Spaces:
Runtime error
Runtime error
#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); | |