#include #include #include #include template void TestSetUnionKeyValue(size_t n) { typedef key_value T; thrust::host_vector h_keys_a = unittest::random_integers(n); thrust::host_vector h_values_a = unittest::random_integers(n); thrust::host_vector h_keys_b = unittest::random_integers(n); thrust::host_vector h_values_b = unittest::random_integers(n); thrust::host_vector h_a(n), h_b(n); for(size_t i = 0; i < n; ++i) { h_a[i] = T(h_keys_a[i], h_values_a[i]); h_b[i] = T(h_keys_b[i], h_values_b[i]); } thrust::stable_sort(h_a.begin(), h_a.end()); thrust::stable_sort(h_b.begin(), h_b.end()); thrust::device_vector d_a = h_a; thrust::device_vector d_b = h_b; thrust::host_vector h_result(h_a.size() + h_b.size()); thrust::device_vector d_result(d_a.size() + d_b.size()); typename thrust::host_vector::iterator h_end; typename thrust::device_vector::iterator d_end; h_end = thrust::set_union(h_a.begin(), h_a.end(), h_b.begin(), h_b.end(), h_result.begin()); h_result.erase(h_end, h_result.end()); d_end = thrust::set_union(d_a.begin(), d_a.end(), d_b.begin(), d_b.end(), d_result.begin()); d_result.erase(d_end, d_result.end()); ASSERT_EQUAL_QUIET(h_result, d_result); } DECLARE_VARIABLE_UNITTEST(TestSetUnionKeyValue); template void TestSetUnionKeyValueDescending(size_t n) { typedef key_value T; thrust::host_vector h_keys_a = unittest::random_integers(n); thrust::host_vector h_values_a = unittest::random_integers(n); thrust::host_vector h_keys_b = unittest::random_integers(n); thrust::host_vector h_values_b = unittest::random_integers(n); thrust::host_vector h_a(n), h_b(n); for(size_t i = 0; i < n; ++i) { h_a[i] = T(h_keys_a[i], h_values_a[i]); h_b[i] = T(h_keys_b[i], h_values_b[i]); } thrust::stable_sort(h_a.begin(), h_a.end(), thrust::greater()); thrust::stable_sort(h_b.begin(), h_b.end(), thrust::greater()); thrust::device_vector d_a = h_a; thrust::device_vector d_b = h_b; thrust::host_vector h_result(h_a.size() + h_b.size()); thrust::device_vector d_result(d_a.size() + d_b.size()); typename thrust::host_vector::iterator h_end; typename thrust::device_vector::iterator d_end; h_end = thrust::set_union(h_a.begin(), h_a.end(), h_b.begin(), h_b.end(), h_result.begin(), thrust::greater()); h_result.erase(h_end, h_result.end()); d_end = thrust::set_union(d_a.begin(), d_a.end(), d_b.begin(), d_b.end(), d_result.begin(), thrust::greater()); d_result.erase(d_end, d_result.end()); ASSERT_EQUAL_QUIET(h_result, d_result); } DECLARE_VARIABLE_UNITTEST(TestSetUnionKeyValueDescending);