Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

remove vectorization #4987

Merged
merged 37 commits into from
Oct 24, 2024
Merged
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
c2c21e1
remove vectorization
AlexGuteniev Sep 27, 2024
d0f2e68
ADL
AlexGuteniev Sep 28, 2024
d6b27af
compress 1-byte data
AlexGuteniev Sep 28, 2024
44a9278
compact also 4 and 8 tables
AlexGuteniev Sep 28, 2024
18c0b7c
reduce copypasta
AlexGuteniev Sep 28, 2024
2b068f6
-leftovers
AlexGuteniev Sep 28, 2024
d99ff0c
wrong comparison!
AlexGuteniev Sep 28, 2024
d0e5938
reduce copypasta even more
AlexGuteniev Sep 28, 2024
7972780
bingo consistency
AlexGuteniev Sep 28, 2024
4a7d60b
vzeroupper
AlexGuteniev Oct 2, 2024
39974d1
mask like floats
AlexGuteniev Oct 4, 2024
3e9109a
also remove shuffle from here
AlexGuteniev Oct 4, 2024
c8ec13b
elaborate comments on the complex part of obtaining the tables
AlexGuteniev Oct 5, 2024
63cb681
doesn't matter, but it is unsigned
AlexGuteniev Oct 5, 2024
61a97c6
what did I say
AlexGuteniev Oct 5, 2024
167c276
no strict
AlexGuteniev Oct 6, 2024
e6dc56d
Still something on SSE4.2 for 32 and 64 bit eleemnts
AlexGuteniev Oct 6, 2024
c48d887
Not patterns just tables
AlexGuteniev Oct 7, 2024
85d69d6
Merge branch 'microsoft:main' into remove
AlexGuteniev Oct 18, 2024
feba29c
Merge remote-tracking branch 'upstream/main' into remove
AlexGuteniev Oct 23, 2024
eaa1ec0
unsigned -> uint32_t
AlexGuteniev Oct 23, 2024
6fb36ce
parts
AlexGuteniev Oct 23, 2024
877a48b
order
AlexGuteniev Oct 23, 2024
7c9fb18
Wait, is it C++20? Always has been
AlexGuteniev Oct 23, 2024
fa245b0
Out of ARM
AlexGuteniev Oct 23, 2024
55e632f
Use `string_view` for `lorem_ipsum`.
StephanTLavavej Oct 23, 2024
dd093d0
Add `const`.
StephanTLavavej Oct 23, 2024
2e704e3
Add `noexcept` to `_Meow_vectorized`.
StephanTLavavej Oct 23, 2024
dc5f773
After calling `_STD` or `_RANGES` `_Find_unchecked`, we know we've fo…
StephanTLavavej Oct 23, 2024
400d778
In C++20, use `to_address`.
StephanTLavavej Oct 23, 2024
93b9222
Drop unnecessary `static_cast`s.
StephanTLavavej Oct 23, 2024
1722ec4
Fix argument order.
StephanTLavavej Oct 23, 2024
0993532
Comment cleanups. Drop the bit about "surprising behavior".
StephanTLavavej Oct 23, 2024
afc9543
Give `_Remove_tables` a name.
StephanTLavavej Oct 23, 2024
2dd0b41
Scope `_Size_bytes` within `if` in `__std_remove_4`.
StephanTLavavej Oct 23, 2024
4fc12f2
Merge branch 'main' into remove (STL's bad MSVC-PR)
StephanTLavavej Oct 24, 2024
4a68a28
Fix the merge conflicts properly.
StephanTLavavej Oct 24, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions benchmarks/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -118,6 +118,7 @@ add_benchmark(mismatch src/mismatch.cpp)
add_benchmark(path_lexically_normal src/path_lexically_normal.cpp)
add_benchmark(priority_queue_push_range src/priority_queue_push_range.cpp)
add_benchmark(random_integer_generation src/random_integer_generation.cpp)
add_benchmark(remove src/remove.cpp)
add_benchmark(replace src/replace.cpp)
add_benchmark(search src/search.cpp)
add_benchmark(std_copy src/std_copy.cpp)
Expand Down
35 changes: 35 additions & 0 deletions benchmarks/inc/lorem.hpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
// Copyright (c) Microsoft Corporation.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception

#pragma once

const char lorem_ipsum[] =
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam mollis imperdiet massa, at dapibus elit interdum "
"ac. In eget sollicitudin mi. Nam at tellus at sapien tincidunt sollicitudin vel non eros. Pellentesque nunc nunc, "
"ullamcorper eu accumsan at, pulvinar non turpis. Quisque vel mauris pulvinar, pretium purus vel, ultricies erat. "
"Curabitur a magna in ligula tristique ornare. Quisque commodo, massa viverra laoreet luctus, sem nisi aliquam "
"velit, fermentum pulvinar velit leo eget justo. Suspendisse vel erat efficitur, pulvinar eros volutpat, vulputate "
"ex. Phasellus non purus vel velit tristique tristique id at ligula. Quisque mollis sodales magna. Mauris et quam "
"eu quam viverra tempus. Nullam tempus maximus porta. Nunc mattis eleifend fermentum. Nullam aliquam libero "
"accumsan velit elementum, eu laoreet metus convallis. Donec pellentesque lacus ut iaculis iaculis. Curabitur orci "
"elit, bibendum sit amet feugiat at, iaculis sit amet massa. Maecenas imperdiet lacus at vehicula iaculis. Donec "
"volutpat nunc sit amet accumsan tempor. Quisque pretium vestibulum ultricies. Suspendisse potenti. Aenean at diam "
"iaculis, condimentum felis venenatis, condimentum erat. Nam quis elit dui. Duis quis odio vitae metus hendrerit "
"rhoncus ut et magna. Cras ac augue quis nibh pharetra sagittis. Donec ullamcorper vel eros semper pretium. Proin "
"vel sollicitudin eros. Nulla sollicitudin mattis turpis id suscipit. Aliquam sed risus velit. Aliquam iaculis nec "
"nibh ac egestas. Duis finibus semper est sed consequat. Sed in sapien quis nibh dignissim mattis. Vestibulum nec "
"metus sodales, euismod mauris ac, sollicitudin libero. Maecenas non arcu ac velit ullamcorper fringilla et quis "
"nulla. Curabitur posuere leo eget ipsum tincidunt dignissim. Cras ultricies suscipit neque, quis suscipit tortor "
"venenatis non. Cras nisl mi, bibendum in vulputate quis, vestibulum ornare enim. Nunc hendrerit placerat dui, "
"aliquam mollis sem convallis et. Integer vitae urna diam. Phasellus et imperdiet est. Maecenas auctor facilisis "
"nibh non commodo. Suspendisse iaculis quam id bibendum feugiat. Pellentesque felis erat, egestas a libero ac, "
"laoreet consectetur elit. Cras ut suscipit ex. Etiam gravida sem quis ex porta, eu lacinia tortor fermentum. "
"Nulla consequat odio enim, sed condimentum est sagittis a. Quisque nec commodo tellus. Phasellus elementum "
"feugiat dolor et feugiat. Praesent sed mattis tortor. In vitae sodales purus. Morbi accumsan, ligula et interdum "
"lacinia, leo risus suscipit urna, non luctus mi justo eu ipsum. Curabitur venenatis pretium orci id porttitor. "
"Quisque dapibus nisl sit amet elit lobortis sagittis. Orci varius natoque penatibus et magnis dis parturient "
"montes, nascetur ridiculus mus. Mauris varius dui sit amet tortor facilisis vestibulum. Curabitur condimentum "
"justo nec orci mattis auctor. Quisque aliquet condimentum arcu ac sollicitudin. Maecenas elit elit, condimentum "
"vitae auctor a, cursus et sem. Cras vehicula ante in consequat fermentum. Praesent at massa nisi. Mauris pretium "
"euismod eros, ut posuere ligula ullamcorper id. Nullam aliquet malesuada est at dignissim. Pellentesque finibus "
"sagittis libero nec bibendum. Phasellus dolor ipsum, finibus quis turpis quis, mollis interdum felis.";
39 changes: 39 additions & 0 deletions benchmarks/src/remove.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
// Copyright (c) Microsoft Corporation.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception

#include <algorithm>
#include <benchmark/benchmark.h>
#include <cstdint>
#include <vector>

#include "lorem.hpp"

enum class alg_type { std_fn, rng };

template <alg_type Type, class T>
void r(benchmark::State& state) {
std::vector<T> src(std::begin(lorem_ipsum), std::end(lorem_ipsum));
StephanTLavavej marked this conversation as resolved.
Show resolved Hide resolved
std::vector<T> v;
v.reserve(std::size(lorem_ipsum));
for (auto _ : state) {
v = src;
benchmark::DoNotOptimize(v);
if constexpr (Type == alg_type::std_fn) {
benchmark::DoNotOptimize(std::remove(v.begin(), v.end(), T{'l'}));
} else {
benchmark::DoNotOptimize(std::ranges::remove(v, T{'l'}));
}
}
}

BENCHMARK(r<alg_type::std_fn, std::uint8_t>);
BENCHMARK(r<alg_type::std_fn, std::uint16_t>);
BENCHMARK(r<alg_type::std_fn, std::uint32_t>);
BENCHMARK(r<alg_type::std_fn, std::uint64_t>);

BENCHMARK(r<alg_type::rng, std::uint8_t>);
BENCHMARK(r<alg_type::rng, std::uint16_t>);
BENCHMARK(r<alg_type::rng, std::uint32_t>);
BENCHMARK(r<alg_type::rng, std::uint64_t>);

BENCHMARK_MAIN();
43 changes: 7 additions & 36 deletions benchmarks/src/replace.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,41 +6,12 @@
#include <cstdint>
#include <vector>

const char src[] =
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam mollis imperdiet massa, at dapibus elit interdum "
"ac. In eget sollicitudin mi. Nam at tellus at sapien tincidunt sollicitudin vel non eros. Pellentesque nunc nunc, "
"ullamcorper eu accumsan at, pulvinar non turpis. Quisque vel mauris pulvinar, pretium purus vel, ultricies erat. "
"Curabitur a magna in ligula tristique ornare. Quisque commodo, massa viverra laoreet luctus, sem nisi aliquam "
"velit, fermentum pulvinar velit leo eget justo. Suspendisse vel erat efficitur, pulvinar eros volutpat, vulputate "
"ex. Phasellus non purus vel velit tristique tristique id at ligula. Quisque mollis sodales magna. Mauris et quam "
"eu quam viverra tempus. Nullam tempus maximus porta. Nunc mattis eleifend fermentum. Nullam aliquam libero "
"accumsan velit elementum, eu laoreet metus convallis. Donec pellentesque lacus ut iaculis iaculis. Curabitur orci "
"elit, bibendum sit amet feugiat at, iaculis sit amet massa. Maecenas imperdiet lacus at vehicula iaculis. Donec "
"volutpat nunc sit amet accumsan tempor. Quisque pretium vestibulum ultricies. Suspendisse potenti. Aenean at diam "
"iaculis, condimentum felis venenatis, condimentum erat. Nam quis elit dui. Duis quis odio vitae metus hendrerit "
"rhoncus ut et magna. Cras ac augue quis nibh pharetra sagittis. Donec ullamcorper vel eros semper pretium. Proin "
"vel sollicitudin eros. Nulla sollicitudin mattis turpis id suscipit. Aliquam sed risus velit. Aliquam iaculis nec "
"nibh ac egestas. Duis finibus semper est sed consequat. Sed in sapien quis nibh dignissim mattis. Vestibulum nec "
"metus sodales, euismod mauris ac, sollicitudin libero. Maecenas non arcu ac velit ullamcorper fringilla et quis "
"nulla. Curabitur posuere leo eget ipsum tincidunt dignissim. Cras ultricies suscipit neque, quis suscipit tortor "
"venenatis non. Cras nisl mi, bibendum in vulputate quis, vestibulum ornare enim. Nunc hendrerit placerat dui, "
"aliquam mollis sem convallis et. Integer vitae urna diam. Phasellus et imperdiet est. Maecenas auctor facilisis "
"nibh non commodo. Suspendisse iaculis quam id bibendum feugiat. Pellentesque felis erat, egestas a libero ac, "
"laoreet consectetur elit. Cras ut suscipit ex. Etiam gravida sem quis ex porta, eu lacinia tortor fermentum. "
"Nulla consequat odio enim, sed condimentum est sagittis a. Quisque nec commodo tellus. Phasellus elementum "
"feugiat dolor et feugiat. Praesent sed mattis tortor. In vitae sodales purus. Morbi accumsan, ligula et interdum "
"lacinia, leo risus suscipit urna, non luctus mi justo eu ipsum. Curabitur venenatis pretium orci id porttitor. "
"Quisque dapibus nisl sit amet elit lobortis sagittis. Orci varius natoque penatibus et magnis dis parturient "
"montes, nascetur ridiculus mus. Mauris varius dui sit amet tortor facilisis vestibulum. Curabitur condimentum "
"justo nec orci mattis auctor. Quisque aliquet condimentum arcu ac sollicitudin. Maecenas elit elit, condimentum "
"vitae auctor a, cursus et sem. Cras vehicula ante in consequat fermentum. Praesent at massa nisi. Mauris pretium "
"euismod eros, ut posuere ligula ullamcorper id. Nullam aliquet malesuada est at dignissim. Pellentesque finibus "
"sagittis libero nec bibendum. Phasellus dolor ipsum, finibus quis turpis quis, mollis interdum felis.";
#include "lorem.hpp"

template <class T>
void r(benchmark::State& state) {
const std::vector<T> a(std::begin(src), std::end(src));
std::vector<T> b(std::size(src));
const std::vector<T> a(std::begin(lorem_ipsum), std::end(lorem_ipsum));
std::vector<T> b(std::size(lorem_ipsum));

for (auto _ : state) {
b = a;
Expand All @@ -50,8 +21,8 @@ void r(benchmark::State& state) {

template <class T>
void rc(benchmark::State& state) {
const std::vector<T> a(std::begin(src), std::end(src));
std::vector<T> b(std::size(src));
const std::vector<T> a(std::begin(lorem_ipsum), std::end(lorem_ipsum));
std::vector<T> b(std::size(lorem_ipsum));

for (auto _ : state) {
std::replace_copy(std::begin(a), std::end(a), std::begin(b), T{'m'}, T{'w'});
Expand All @@ -60,8 +31,8 @@ void rc(benchmark::State& state) {

template <class T>
void rc_if(benchmark::State& state) {
const std::vector<T> a(std::begin(src), std::end(src));
std::vector<T> b(std::size(src));
const std::vector<T> a(std::begin(lorem_ipsum), std::end(lorem_ipsum));
std::vector<T> b(std::size(lorem_ipsum));

for (auto _ : state) {
(void) std::replace_copy_if(
Expand Down
40 changes: 6 additions & 34 deletions benchmarks/src/search.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,38 +10,10 @@
#include <string>
#include <string_view>
#include <vector>

#include "lorem.hpp"
using namespace std::string_view_literals;

const char src_haystack[] =
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam mollis imperdiet massa, at dapibus elit interdum "
"ac. In eget sollicitudin mi. Nam at tellus at sapien tincidunt sollicitudin vel non eros. Pellentesque nunc nunc, "
"ullamcorper eu accumsan at, pulvinar non turpis. Quisque vel mauris pulvinar, pretium purus vel, ultricies erat. "
"Curabitur a magna in ligula tristique ornare. Quisque commodo, massa viverra laoreet luctus, sem nisi aliquam "
"velit, fermentum pulvinar velit leo eget justo. Suspendisse vel erat efficitur, pulvinar eros volutpat, vulputate "
"ex. Phasellus non purus vel velit tristique tristique id at ligula. Quisque mollis sodales magna. Mauris et quam "
"eu quam viverra tempus. Nullam tempus maximus porta. Nunc mattis eleifend fermentum. Nullam aliquam libero "
"accumsan velit elementum, eu laoreet metus convallis. Donec pellentesque lacus ut iaculis iaculis. Curabitur orci "
"elit, bibendum sit amet feugiat at, iaculis sit amet massa. Maecenas imperdiet lacus at vehicula iaculis. Donec "
"volutpat nunc sit amet accumsan tempor. Quisque pretium vestibulum ultricies. Suspendisse potenti. Aenean at diam "
"iaculis, condimentum felis venenatis, condimentum erat. Nam quis elit dui. Duis quis odio vitae metus hendrerit "
"rhoncus ut et magna. Cras ac augue quis nibh pharetra sagittis. Donec ullamcorper vel eros semper pretium. Proin "
"vel sollicitudin eros. Nulla sollicitudin mattis turpis id suscipit. Aliquam sed risus velit. Aliquam iaculis nec "
"nibh ac egestas. Duis finibus semper est sed consequat. Sed in sapien quis nibh dignissim mattis. Vestibulum nec "
"metus sodales, euismod mauris ac, sollicitudin libero. Maecenas non arcu ac velit ullamcorper fringilla et quis "
"nulla. Curabitur posuere leo eget ipsum tincidunt dignissim. Cras ultricies suscipit neque, quis suscipit tortor "
"venenatis non. Cras nisl mi, bibendum in vulputate quis, vestibulum ornare enim. Nunc hendrerit placerat dui, "
"aliquam mollis sem convallis et. Integer vitae urna diam. Phasellus et imperdiet est. Maecenas auctor facilisis "
"nibh non commodo. Suspendisse iaculis quam id bibendum feugiat. Pellentesque felis erat, egestas a libero ac, "
"laoreet consectetur elit. Cras ut suscipit ex. Etiam gravida sem quis ex porta, eu lacinia tortor fermentum. "
"Nulla consequat odio enim, sed condimentum est sagittis a. Quisque nec commodo tellus. Phasellus elementum "
"feugiat dolor et feugiat. Praesent sed mattis tortor. In vitae sodales purus. Morbi accumsan, ligula et interdum "
"lacinia, leo risus suscipit urna, non luctus mi justo eu ipsum. Curabitur venenatis pretium orci id porttitor. "
"Quisque dapibus nisl sit amet elit lobortis sagittis. Orci varius natoque penatibus et magnis dis parturient "
"montes, nascetur ridiculus mus. Mauris varius dui sit amet tortor facilisis vestibulum. Curabitur condimentum "
"justo nec orci mattis auctor. Quisque aliquet condimentum arcu ac sollicitudin. Maecenas elit elit, condimentum "
"vitae auctor a, cursus et sem. Cras vehicula ante in consequat fermentum. Praesent at massa nisi. Mauris pretium "
"euismod eros, ut posuere ligula ullamcorper id. Nullam aliquet malesuada est at dignissim. Pellentesque finibus "
"sagittis libero nec bibendum. Phasellus dolor ipsum, finibus quis turpis quis, mollis interdum felis.";

constexpr std::array patterns = {
"aliquet"sv,
Expand All @@ -51,7 +23,7 @@ constexpr std::array patterns = {
void c_strstr(benchmark::State& state) {
const auto& src_needle = patterns[static_cast<size_t>(state.range())];

const std::string haystack(std::begin(src_haystack), std::end(src_haystack));
const std::string haystack(std::begin(lorem_ipsum), std::end(lorem_ipsum));
const std::string needle(std::begin(src_needle), std::end(src_needle));

for (auto _ : state) {
Expand All @@ -66,7 +38,7 @@ template <class T>
void classic_search(benchmark::State& state) {
const auto& src_needle = patterns[static_cast<size_t>(state.range())];

const std::vector<T> haystack(std::begin(src_haystack), std::end(src_haystack));
const std::vector<T> haystack(std::begin(lorem_ipsum), std::end(lorem_ipsum));
const std::vector<T> needle(std::begin(src_needle), std::end(src_needle));

for (auto _ : state) {
Expand All @@ -81,7 +53,7 @@ template <class T>
void ranges_search(benchmark::State& state) {
const auto& src_needle = patterns[static_cast<size_t>(state.range())];

const std::vector<T> haystack(std::begin(src_haystack), std::end(src_haystack));
const std::vector<T> haystack(std::begin(lorem_ipsum), std::end(lorem_ipsum));
const std::vector<T> needle(std::begin(src_needle), std::end(src_needle));

for (auto _ : state) {
Expand All @@ -96,7 +68,7 @@ template <class T>
void search_default_searcher(benchmark::State& state) {
const auto& src_needle = patterns[static_cast<size_t>(state.range())];

const std::vector<T> haystack(std::begin(src_haystack), std::end(src_haystack));
const std::vector<T> haystack(std::begin(lorem_ipsum), std::end(lorem_ipsum));
const std::vector<T> needle(std::begin(src_needle), std::end(src_needle));

for (auto _ : state) {
Expand Down
23 changes: 2 additions & 21 deletions benchmarks/src/sv_equal.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,28 +8,9 @@
#include <ranges>
#include <string_view>

using namespace std::string_view_literals;
#include "lorem.hpp"

constexpr auto haystack =
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam mollis imperdiet massa, at dapibus elit "
"interdumac. In eget sollicitudin mi. Nam at tellus at sapien tincidunt sollicitudin vel non eros. Pellentesque "
"nunc nunc,ullamcorper eu accumsan at, pulvinar non turpis. Quisque vel mauris pulvinar, pretium purus vel, "
"ultricies erat.Curabitur a magna in ligula tristique ornare. Quisque commodo, massa viverra laoreet luctus, sem "
"nisi aliquamvelit, fermentum pulvinar velit leo eget justo. Suspendisse vel erat efficitur, pulvinar eros "
"volutpat, vulputateex. Phasellus non purus vel velit tristique tristique id at ligula. Quisque mollis sodales "
"magna. Mauris et quameu quam viverra tempus. Nullam tempus maximus porta. Nunc mattis eleifend fermentum. Nullam "
"aliquam liberoaccumsan velit elementum, eu laoreet metus convallis. Donec pellentesque lacus ut iaculis iaculis. "
"Curabitur orcielit, bibendum sit amet feugiat at, iaculis sit amet massa. Maecenas imperdiet lacus at vehicula "
"iaculis. Donecvolutpat nunc sit amet accumsan tempor. Quisque pretium vestibulum ultricies. Suspendisse potenti. "
"Aenean at diamiaculis, condimentum felis venenatis, condimentum erat. Nam quis elit dui. Duis quis odio vitae "
"metus hendreritrhoncus ut et magna. Cras ac augue quis nibh pharetra sagittis. Donec ullamcorper vel eros semper "
"pretium. Proinvel sollicitudin eros. Nulla sollicitudin mattis turpis id suscipit. Aliquam sed risus velit. "
"Aliquam iaculis necnibh ac egestas. Duis finibus semper est sed consequat. Sed in sapien quis nibh dignissim "
"mattis. Vestibulum necmetus sodales, euismod mauris ac, sollicitudin libero. Maecenas non arcu ac velit "
"ullamcorper fringilla et quisnulla. Curabitur posuere leo eget ipsum tincidunt dignissim. Cras ultricies suscipit "
"neque, quis suscipit tortorvenenatis non. Cras nisl mi, bibendum in vulputate quis, vestibulum ornare enim. Nunc "
"hendrerit placerat dui,aliquam mollis sem convallis et. Integer vitae urna diam. Phasellus et imperdiet est. "
"Maecenas auctor facilisisnibh non commodo. Suspendisse iaculis quam "sv;
constexpr std::string_view haystack(lorem_ipsum, lorem_ipsum + 2048);
StephanTLavavej marked this conversation as resolved.
Show resolved Hide resolved

constexpr std::size_t Count = 8u;

Expand Down
21 changes: 21 additions & 0 deletions stl/inc/algorithm
Original file line number Diff line number Diff line change
Expand Up @@ -4589,6 +4589,27 @@ namespace ranges {
_STL_INTERNAL_STATIC_ASSERT(sentinel_for<_Se, _It>);
_STL_INTERNAL_STATIC_ASSERT(indirect_binary_predicate<ranges::equal_to, projected<_It, _Pj>, const _Ty*>);

#if _USE_STD_VECTOR_ALGORITHMS
if constexpr (_Vector_alg_in_find_is_safe<_It, _Ty> && sized_sentinel_for<_Se, _It>
&& is_same_v<_Pj, identity>) {
if (!_STD is_constant_evaluated()) {
const auto _Size = _Last - _First;
if (!_STD _Could_compare_equal_to_value_type<_It>(_Val)) {
return {_First + _Size, _First + _Size};
}
const auto _First_ptr = _STD _To_address(_First);
StephanTLavavej marked this conversation as resolved.
Show resolved Hide resolved
const auto _Last_ptr = _First_ptr + static_cast<size_t>(_Size);
const auto _Result = _STD _Remove_vectorized(_First_ptr, _Last_ptr, _Val);

if constexpr (is_pointer_v<_It>) {
return {static_cast<_It>(_Result), static_cast<_It>(_Last_ptr)};
StephanTLavavej marked this conversation as resolved.
Show resolved Hide resolved
} else {
return {_First + (_Result - _First_ptr), _First + _Size};
}
}
}
#endif // _USE_STD_VECTOR_ALGORITHMS

_First = _RANGES _Find_unchecked(_STD move(_First), _Last, _Val, _Proj);
auto _Next = _First;
if (_First == _Last) {
Expand Down
Loading