#include #include #include template __global__ void swap_ranges_kernel(ExecutionPolicy exec, Iterator1 first1, Iterator1 last1, Iterator2 first2) { thrust::swap_ranges(exec, first1, last1, first2); } template void TestSwapRangesDevice(ExecutionPolicy exec) { typedef thrust::device_vector Vector; Vector v1(5); v1[0] = 0; v1[1] = 1; v1[2] = 2; v1[3] = 3; v1[4] = 4; Vector v2(5); v2[0] = 5; v2[1] = 6; v2[2] = 7; v2[3] = 8; v2[4] = 9; swap_ranges_kernel<<<1,1>>>(exec, v1.begin(), v1.end(), v2.begin()); cudaError_t const err = cudaDeviceSynchronize(); ASSERT_EQUAL(cudaSuccess, err); ASSERT_EQUAL(v1[0], 5); ASSERT_EQUAL(v1[1], 6); ASSERT_EQUAL(v1[2], 7); ASSERT_EQUAL(v1[3], 8); ASSERT_EQUAL(v1[4], 9); ASSERT_EQUAL(v2[0], 0); ASSERT_EQUAL(v2[1], 1); ASSERT_EQUAL(v2[2], 2); ASSERT_EQUAL(v2[3], 3); ASSERT_EQUAL(v2[4], 4); } void TestSwapRangesDeviceSeq() { TestSwapRangesDevice(thrust::seq); } DECLARE_UNITTEST(TestSwapRangesDeviceSeq); void TestSwapRangesDeviceDevice() { TestSwapRangesDevice(thrust::device); } DECLARE_UNITTEST(TestSwapRangesDeviceDevice); void TestSwapRangesCudaStreams() { typedef thrust::device_vector Vector; Vector v1(5); v1[0] = 0; v1[1] = 1; v1[2] = 2; v1[3] = 3; v1[4] = 4; Vector v2(5); v2[0] = 5; v2[1] = 6; v2[2] = 7; v2[3] = 8; v2[4] = 9; cudaStream_t s; cudaStreamCreate(&s); thrust::swap_ranges(thrust::cuda::par.on(s), v1.begin(), v1.end(), v2.begin()); cudaStreamSynchronize(s); ASSERT_EQUAL(v1[0], 5); ASSERT_EQUAL(v1[1], 6); ASSERT_EQUAL(v1[2], 7); ASSERT_EQUAL(v1[3], 8); ASSERT_EQUAL(v1[4], 9); ASSERT_EQUAL(v2[0], 0); ASSERT_EQUAL(v2[1], 1); ASSERT_EQUAL(v2[2], 2); ASSERT_EQUAL(v2[3], 3); ASSERT_EQUAL(v2[4], 4); cudaStreamDestroy(s); } DECLARE_UNITTEST(TestSwapRangesCudaStreams);