#include #include #include #include #include #include THRUST_DISABLE_MSVC_POSSIBLE_LOSS_OF_DATA_WARNING_BEGIN template void TestFillSimple(void) { typedef typename Vector::value_type T; Vector v(5); v[0] = 0; v[1] = 1; v[2] = 2; v[3] = 3; v[4] = 4; thrust::fill(v.begin() + 1, v.begin() + 4, (T) 7); ASSERT_EQUAL(v[0], 0); ASSERT_EQUAL(v[1], 7); ASSERT_EQUAL(v[2], 7); ASSERT_EQUAL(v[3], 7); ASSERT_EQUAL(v[4], 4); thrust::fill(v.begin() + 0, v.begin() + 3, (T) 8); ASSERT_EQUAL(v[0], 8); ASSERT_EQUAL(v[1], 8); ASSERT_EQUAL(v[2], 8); ASSERT_EQUAL(v[3], 7); ASSERT_EQUAL(v[4], 4); thrust::fill(v.begin() + 2, v.end(), (T) 9); ASSERT_EQUAL(v[0], 8); ASSERT_EQUAL(v[1], 8); ASSERT_EQUAL(v[2], 9); ASSERT_EQUAL(v[3], 9); ASSERT_EQUAL(v[4], 9); thrust::fill(v.begin(), v.end(), (T) 1); ASSERT_EQUAL(v[0], 1); ASSERT_EQUAL(v[1], 1); ASSERT_EQUAL(v[2], 1); ASSERT_EQUAL(v[3], 1); ASSERT_EQUAL(v[4], 1); } DECLARE_VECTOR_UNITTEST(TestFillSimple); void TestFillDiscardIterator(void) { // there's no result to check because fill returns void thrust::fill(thrust::discard_iterator(), thrust::discard_iterator(10), 13); thrust::fill(thrust::discard_iterator(), thrust::discard_iterator(10), 13); } DECLARE_UNITTEST(TestFillDiscardIterator); template void TestFillMixedTypes(void) { Vector v(4); thrust::fill(v.begin(), v.end(), bool(true)); ASSERT_EQUAL(v[0], 1); ASSERT_EQUAL(v[1], 1); ASSERT_EQUAL(v[2], 1); ASSERT_EQUAL(v[3], 1); thrust::fill(v.begin(), v.end(), char(20)); ASSERT_EQUAL(v[0], 20); ASSERT_EQUAL(v[1], 20); ASSERT_EQUAL(v[2], 20); ASSERT_EQUAL(v[3], 20); } DECLARE_VECTOR_UNITTEST(TestFillMixedTypes); template void TestFill(size_t n) { thrust::host_vector h_data = unittest::random_integers(n); thrust::device_vector d_data = h_data; thrust::fill(h_data.begin() + std::min((size_t)1, n), h_data.begin() + std::min((size_t)3, n), (T) 0); thrust::fill(d_data.begin() + std::min((size_t)1, n), d_data.begin() + std::min((size_t)3, n), (T) 0); ASSERT_EQUAL(h_data, d_data); thrust::fill(h_data.begin() + std::min((size_t)117, n), h_data.begin() + std::min((size_t)367, n), (T) 1); thrust::fill(d_data.begin() + std::min((size_t)117, n), d_data.begin() + std::min((size_t)367, n), (T) 1); ASSERT_EQUAL(h_data, d_data); thrust::fill(h_data.begin() + std::min((size_t)8, n), h_data.begin() + std::min((size_t)259, n), (T) 2); thrust::fill(d_data.begin() + std::min((size_t)8, n), d_data.begin() + std::min((size_t)259, n), (T) 2); ASSERT_EQUAL(h_data, d_data); thrust::fill(h_data.begin() + std::min((size_t)3, n), h_data.end(), (T) 3); thrust::fill(d_data.begin() + std::min((size_t)3, n), d_data.end(), (T) 3); ASSERT_EQUAL(h_data, d_data); thrust::fill(h_data.begin(), h_data.end(), (T) 4); thrust::fill(d_data.begin(), d_data.end(), (T) 4); ASSERT_EQUAL(h_data, d_data); } DECLARE_VARIABLE_UNITTEST(TestFill); template void TestFillNSimple(void) { typedef typename Vector::value_type T; Vector v(5); v[0] = 0; v[1] = 1; v[2] = 2; v[3] = 3; v[4] = 4; typename Vector::iterator iter = thrust::fill_n(v.begin() + 1, 3, (T) 7); ASSERT_EQUAL(v[0], 0); ASSERT_EQUAL(v[1], 7); ASSERT_EQUAL(v[2], 7); ASSERT_EQUAL(v[3], 7); ASSERT_EQUAL(v[4], 4); ASSERT_EQUAL_QUIET(v.begin() + 4, iter); iter = thrust::fill_n(v.begin() + 0, 3, (T) 8); ASSERT_EQUAL(v[0], 8); ASSERT_EQUAL(v[1], 8); ASSERT_EQUAL(v[2], 8); ASSERT_EQUAL(v[3], 7); ASSERT_EQUAL(v[4], 4); ASSERT_EQUAL_QUIET(v.begin() + 3, iter); iter = thrust::fill_n(v.begin() + 2, 3, (T) 9); ASSERT_EQUAL(v[0], 8); ASSERT_EQUAL(v[1], 8); ASSERT_EQUAL(v[2], 9); ASSERT_EQUAL(v[3], 9); ASSERT_EQUAL(v[4], 9); ASSERT_EQUAL_QUIET(v.end(), iter); iter = thrust::fill_n(v.begin(), v.size(), (T) 1); ASSERT_EQUAL(v[0], 1); ASSERT_EQUAL(v[1], 1); ASSERT_EQUAL(v[2], 1); ASSERT_EQUAL(v[3], 1); ASSERT_EQUAL(v[4], 1); ASSERT_EQUAL_QUIET(v.end(), iter); } DECLARE_VECTOR_UNITTEST(TestFillNSimple); void TestFillNDiscardIterator(void) { thrust::discard_iterator h_result = thrust::fill_n(thrust::discard_iterator(), 10, 13); thrust::discard_iterator d_result = thrust::fill_n(thrust::discard_iterator(), 10, 13); thrust::discard_iterator<> reference(10); ASSERT_EQUAL_QUIET(reference, h_result); ASSERT_EQUAL_QUIET(reference, d_result); } DECLARE_UNITTEST(TestFillNDiscardIterator); template void TestFillNMixedTypes(void) { Vector v(4); typename Vector::iterator iter = thrust::fill_n(v.begin(), v.size(), bool(true)); ASSERT_EQUAL(v[0], 1); ASSERT_EQUAL(v[1], 1); ASSERT_EQUAL(v[2], 1); ASSERT_EQUAL(v[3], 1); ASSERT_EQUAL_QUIET(v.end(), iter); iter = thrust::fill_n(v.begin(), v.size(), char(20)); ASSERT_EQUAL(v[0], 20); ASSERT_EQUAL(v[1], 20); ASSERT_EQUAL(v[2], 20); ASSERT_EQUAL(v[3], 20); ASSERT_EQUAL_QUIET(v.end(), iter); } DECLARE_VECTOR_UNITTEST(TestFillNMixedTypes); template void TestFillN(size_t n) { thrust::host_vector h_data = unittest::random_integers(n); thrust::device_vector d_data = h_data; size_t begin_offset = std::min(1,n); thrust::fill_n(h_data.begin() + begin_offset, std::min((size_t)3, n) - begin_offset, (T) 0); thrust::fill_n(d_data.begin() + begin_offset, std::min((size_t)3, n) - begin_offset, (T) 0); ASSERT_EQUAL(h_data, d_data); begin_offset = std::min(117, n); thrust::fill_n(h_data.begin() + begin_offset, std::min((size_t)367, n) - begin_offset, (T) 1); thrust::fill_n(d_data.begin() + begin_offset, std::min((size_t)367, n) - begin_offset, (T) 1); ASSERT_EQUAL(h_data, d_data); begin_offset = std::min(8, n); thrust::fill_n(h_data.begin() + begin_offset, std::min((size_t)259, n) - begin_offset, (T) 2); thrust::fill_n(d_data.begin() + begin_offset, std::min((size_t)259, n) - begin_offset, (T) 2); ASSERT_EQUAL(h_data, d_data); begin_offset = std::min(3, n); thrust::fill_n(h_data.begin() + begin_offset, h_data.size() - begin_offset, (T) 3); thrust::fill_n(d_data.begin() + begin_offset, d_data.size() - begin_offset, (T) 3); ASSERT_EQUAL(h_data, d_data); thrust::fill_n(h_data.begin(), h_data.size(), (T) 4); thrust::fill_n(d_data.begin(), d_data.size(), (T) 4); ASSERT_EQUAL(h_data, d_data); } DECLARE_VARIABLE_UNITTEST(TestFillN); template void TestFillZipIterator(void) { typedef typename Vector::value_type T; Vector v1(3,T(0)); Vector v2(3,T(0)); Vector v3(3,T(0)); thrust::fill(thrust::make_zip_iterator(thrust::make_tuple(v1.begin(),v2.begin(),v3.begin())), thrust::make_zip_iterator(thrust::make_tuple(v1.end(),v2.end(),v3.end())), thrust::tuple(4,7,13)); ASSERT_EQUAL(4, v1[0]); ASSERT_EQUAL(4, v1[1]); ASSERT_EQUAL(4, v1[2]); ASSERT_EQUAL(7, v2[0]); ASSERT_EQUAL(7, v2[1]); ASSERT_EQUAL(7, v2[2]); ASSERT_EQUAL(13, v3[0]); ASSERT_EQUAL(13, v3[1]); ASSERT_EQUAL(13, v3[2]); }; DECLARE_VECTOR_UNITTEST(TestFillZipIterator); void TestFillTuple(void) { typedef int T; typedef thrust::tuple Tuple; thrust::host_vector h(3, Tuple(0,0)); thrust::device_vector d(3, Tuple(0,0)); thrust::fill(h.begin(), h.end(), Tuple(4,7)); thrust::fill(d.begin(), d.end(), Tuple(4,7)); ASSERT_EQUAL_QUIET(h, d); }; DECLARE_UNITTEST(TestFillTuple); struct TypeWithTrivialAssigment { int x, y, z; }; void TestFillWithTrivialAssignment(void) { typedef TypeWithTrivialAssigment T; thrust::host_vector h(1); thrust::device_vector d(1); ASSERT_EQUAL(h[0].x, 0); ASSERT_EQUAL(h[0].y, 0); ASSERT_EQUAL(h[0].z, 0); ASSERT_EQUAL(static_cast(d[0]).x, 0); ASSERT_EQUAL(static_cast(d[0]).y, 0); ASSERT_EQUAL(static_cast(d[0]).z, 0); T val; val.x = 10; val.y = 20; val.z = -1; thrust::fill(h.begin(), h.end(), val); thrust::fill(d.begin(), d.end(), val); ASSERT_EQUAL(h[0].x, 10); ASSERT_EQUAL(h[0].y, 20); ASSERT_EQUAL(h[0].z, -1); ASSERT_EQUAL(static_cast(d[0]).x, 10); ASSERT_EQUAL(static_cast(d[0]).y, 20); ASSERT_EQUAL(static_cast(d[0]).z, -1); }; DECLARE_UNITTEST(TestFillWithTrivialAssignment); struct TypeWithNonTrivialAssigment { int x, y, z; __host__ __device__ TypeWithNonTrivialAssigment() : x(0), y(0), z(0) {} #if THRUST_CPP_DIALECT >= 2011 TypeWithNonTrivialAssigment(const TypeWithNonTrivialAssigment &) = default; #endif __host__ __device__ TypeWithNonTrivialAssigment& operator=(const TypeWithNonTrivialAssigment& t) { x = t.x; y = t.y; z = t.x + t.y; return *this; } __host__ __device__ bool operator==(const TypeWithNonTrivialAssigment& t) const { return x == t.x && y == t.y && z == t.z; } }; void TestFillWithNonTrivialAssignment(void) { typedef TypeWithNonTrivialAssigment T; thrust::host_vector h(1); thrust::device_vector d(1); ASSERT_EQUAL(h[0].x, 0); ASSERT_EQUAL(h[0].y, 0); ASSERT_EQUAL(h[0].z, 0); ASSERT_EQUAL(static_cast(d[0]).x, 0); ASSERT_EQUAL(static_cast(d[0]).y, 0); ASSERT_EQUAL(static_cast(d[0]).z, 0); T val; val.x = 10; val.y = 20; val.z = -1; thrust::fill(h.begin(), h.end(), val); thrust::fill(d.begin(), d.end(), val); ASSERT_EQUAL(h[0].x, 10); ASSERT_EQUAL(h[0].y, 20); ASSERT_EQUAL(h[0].z, 30); ASSERT_EQUAL(static_cast(d[0]).x, 10); ASSERT_EQUAL(static_cast(d[0]).y, 20); ASSERT_EQUAL(static_cast(d[0]).z, 30); }; DECLARE_UNITTEST(TestFillWithNonTrivialAssignment); template void fill(my_system &system, ForwardIterator /*first*/, ForwardIterator, const T&) { system.validate_dispatch(); } void TestFillDispatchExplicit() { thrust::device_vector vec(1); my_system sys(0); thrust::fill(sys, vec.begin(), vec.end(), 0); ASSERT_EQUAL(true, sys.is_valid()); } DECLARE_UNITTEST(TestFillDispatchExplicit); template void fill(my_tag, ForwardIterator first, ForwardIterator, const T&) { *first = 13; } void TestFillDispatchImplicit() { thrust::device_vector vec(1); thrust::fill(thrust::retag(vec.begin()), thrust::retag(vec.end()), 0); ASSERT_EQUAL(13, vec.front()); } DECLARE_UNITTEST(TestFillDispatchImplicit); template OutputIterator fill_n(my_system &system, OutputIterator first, Size, const T&) { system.validate_dispatch(); return first; } void TestFillNDispatchExplicit() { thrust::device_vector vec(1); my_system sys(0); thrust::fill_n(sys, vec.begin(), vec.size(), 0); ASSERT_EQUAL(true, sys.is_valid()); } DECLARE_UNITTEST(TestFillNDispatchExplicit); template OutputIterator fill_n(my_tag, OutputIterator first, Size, const T&) { *first = 13; return first; } void TestFillNDispatchImplicit() { thrust::device_vector vec(1); thrust::fill_n(thrust::retag(vec.begin()), vec.size(), 0); ASSERT_EQUAL(13, vec.front()); } DECLARE_UNITTEST(TestFillNDispatchImplicit); THRUST_DISABLE_MSVC_POSSIBLE_LOSS_OF_DATA_WARNING_END