- "serial execution instead of execution with a policy". Fixed.
- Got rid of the overheads connected with usage of std::distance for "forward" iterators. In that case we had N additional steps - an iterator seeking. Actually std::equal serial version (C++17 library) does it.
Details
Diff Detail
- Repository
- rPSTL pstl
Event Timeline
include/pstl/internal/algorithm_impl.h | ||
---|---|---|
409 | This can also be called as std::equal(first1, last1, first2, last2, pred). Is there any reason why we don't assume the presence of the usual std::equal? | |
426 | This is all something that the serial std::equal does, and I'm uncomfortable with duplicating this logic here. | |
466 | Can you please put your changes through clang-format? |
include/pstl/internal/algorithm_impl.h | ||
---|---|---|
409 | std::equal(first1, last1, first2, last2... supported since C++14... Parallel STL open source version has min requirement C++11. Actually, we can add a macro __PSTL_EQUAL_ALGO_VERSION_2_PRESENT | |
426 | Hm... I've had a look. | |
466 | Of course |
include/pstl/internal/algorithm_impl.h | ||
---|---|---|
409 | The parallel algorithms are a C++17 addition, and as such they can require C++17 support. |
- Usage of std::equal with "4 iterators" (due to it is available in C++ standard library since C++14)
- Clang formatted
Can you please rebase on top of latest master? This doesn't apply cleanly anymore since the uglification patches.
+ compilation fixes (lost "__").
Actually, I have not yet got "Restructure test suite to follow libc++ standard layout" changes in my local repo because there are some problems with starting our test via make files on the restructured nested test folders..
But, my old "test_algo" with the "HEAD" of the master is passed.
The tests you must run when contributing to this repository are the CMake ones. ninja -C <build-dir> check-pstl should pass.
To clarify -- it's entirely fine to have internal tests for your internal "fork" of PSTL and to run them. However, when contributing to the upstream repo, we expect the upstream tests to be passing.
We have the same situation for libc++ and libc++abi, where some vendors may have custom tests internally and they keep them passing. But when contributing upstream, they make sure that check-cxx is passing.
Currently I get:
<...>/llvm/pstl/include/pstl/internal/algorithm_impl.h:414:12: error: no matching function for call to 'equal' return std::equal(__first1, __last1, __first2, __last2, __p); ^~~~~~~~~~ <...>/llvm/pstl/include/pstl/internal/algorithm_impl.h:436:24: note: in instantiation of function template specialization '__pstl::__internal::__brick_equal<std::__1::__wrap_iter<int *>, std::__1::__wrap_iter<int *>, TestUtils::NonConstAdapter<std::__1::equal_to<int> > >' requested here return __internal::__brick_equal(__first1, __last1, __first2, __last2, __p, __is_vector); ^ <...>/llvm/pstl/include/pstl/internal/glue_algorithm_impl.h:749:24: note: in instantiation of function template specialization '__pstl::__internal::__pattern_equal<const __pstl::execution::v1::sequenced_policy &, std::__1::__wrap_iter<int *>, std::__1::__wrap_iter<int *>, TestUtils::NonConstAdapter<std::__1::equal_to<int> >, std::__1::integral_constant<bool, false> >' requested here return __internal::__pattern_equal(std::forward<_ExecutionPolicy>(__exec), __first1, __last1, __first2, __last2, __p,
etc...
Louis,
regarding
..no matching function for call to 'equal' return std::equal(first1, last1, first2, last2, __p);
Do you have an option ?
-std=c++17
We discussed it, that std::equal with "4 iterators" version supported since C++17 only.
Yes, that was it. See r357609. But my point about running the upstream tests still stands.
You don't strictly need ninja (ninja is awesome though), just CMake and make.
I typically create a parallel build tree, with build subdirs per working branch, e.g.
src/oss/pstl/master
src/oss/pstl/build/master
Given that, cd into build/master and -
cmake ../../master
make pstl-build-tests
make test
This can also be called as std::equal(first1, last1, first2, last2, pred). Is there any reason why we don't assume the presence of the usual std::equal?