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); | |