catboost 1.25.1 → 1.26.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/DEPLOYMENT.md +22 -15
- package/README.md +37 -27
- package/binding.gyp +5 -7
- package/build_scripts/bootstrap.js +2 -1
- package/build_scripts/out/build.js +46 -68
- package/build_scripts/out/build_model.js +1 -1
- package/build_scripts/out/{build_ya.js → build_native.js} +1 -1
- package/build_scripts/out/ci.js +5 -5
- package/build_scripts/out/config.js +32 -18
- package/build_scripts/out/install.js +5 -3
- package/build_scripts/out/package_prepublish.js +1 -1
- package/build_scripts/out/packaging.js +1 -19
- package/build_scripts/out/run_tests.js +1 -1
- package/build_scripts/out/test.js +8 -3
- package/config.json +18 -11
- package/inc/catboost/libs/model_interface/c_api.h +349 -3
- package/lib/catboost.d.ts +65 -21
- package/package.json +4 -4
- package/src/api_helpers.cpp +100 -24
- package/src/api_helpers.h +8 -7
- package/src/api_module.cpp +1 -2
- package/src/model.cpp +483 -83
- package/src/model.h +24 -9
- package/inc/contrib/libs/cxxsupp/system_stl/include/stlfwd +0 -14
- package/inc/util/charset/recode_result.h +0 -9
- package/inc/util/charset/unicode_table.h +0 -123
- package/inc/util/charset/unidata.h +0 -421
- package/inc/util/charset/utf8.h +0 -384
- package/inc/util/charset/wide.h +0 -843
- package/inc/util/charset/wide_specific.h +0 -22
- package/inc/util/datetime/base.h +0 -669
- package/inc/util/datetime/constants.h +0 -7
- package/inc/util/datetime/cputimer.h +0 -124
- package/inc/util/datetime/parser.h +0 -292
- package/inc/util/datetime/systime.h +0 -47
- package/inc/util/datetime/uptime.h +0 -8
- package/inc/util/digest/city.h +0 -88
- package/inc/util/digest/fnv.h +0 -73
- package/inc/util/digest/multi.h +0 -14
- package/inc/util/digest/murmur.h +0 -57
- package/inc/util/digest/numeric.h +0 -86
- package/inc/util/digest/sequence.h +0 -48
- package/inc/util/draft/date.h +0 -129
- package/inc/util/draft/datetime.h +0 -184
- package/inc/util/draft/enum.h +0 -136
- package/inc/util/draft/holder_vector.h +0 -102
- package/inc/util/draft/ip.h +0 -131
- package/inc/util/draft/matrix.h +0 -108
- package/inc/util/draft/memory.h +0 -40
- package/inc/util/folder/dirent_win.h +0 -46
- package/inc/util/folder/dirut.h +0 -121
- package/inc/util/folder/filelist.h +0 -81
- package/inc/util/folder/fts.h +0 -108
- package/inc/util/folder/iterator.h +0 -109
- package/inc/util/folder/lstat_win.h +0 -20
- package/inc/util/folder/path.h +0 -225
- package/inc/util/folder/pathsplit.h +0 -113
- package/inc/util/folder/tempdir.h +0 -42
- package/inc/util/generic/adaptor.h +0 -134
- package/inc/util/generic/algorithm.h +0 -765
- package/inc/util/generic/array_ref.h +0 -282
- package/inc/util/generic/array_size.h +0 -24
- package/inc/util/generic/benchmark/vector_count_ctor/f.h +0 -9
- package/inc/util/generic/bitmap.h +0 -1115
- package/inc/util/generic/bitops.h +0 -459
- package/inc/util/generic/bt_exception.h +0 -24
- package/inc/util/generic/buffer.h +0 -232
- package/inc/util/generic/cast.h +0 -176
- package/inc/util/generic/deque.h +0 -24
- package/inc/util/generic/explicit_type.h +0 -42
- package/inc/util/generic/fastqueue.h +0 -55
- package/inc/util/generic/flags.h +0 -244
- package/inc/util/generic/function.h +0 -103
- package/inc/util/generic/fwd.h +0 -171
- package/inc/util/generic/guid.h +0 -61
- package/inc/util/generic/hash.h +0 -2032
- package/inc/util/generic/hash_primes.h +0 -140
- package/inc/util/generic/hash_set.h +0 -490
- package/inc/util/generic/hide_ptr.h +0 -3
- package/inc/util/generic/intrlist.h +0 -876
- package/inc/util/generic/is_in.h +0 -53
- package/inc/util/generic/iterator.h +0 -137
- package/inc/util/generic/iterator_range.h +0 -105
- package/inc/util/generic/lazy_value.h +0 -66
- package/inc/util/generic/list.h +0 -22
- package/inc/util/generic/map.h +0 -44
- package/inc/util/generic/mapfindptr.h +0 -60
- package/inc/util/generic/maybe.h +0 -713
- package/inc/util/generic/maybe_traits.h +0 -164
- package/inc/util/generic/mem_copy.h +0 -55
- package/inc/util/generic/noncopyable.h +0 -38
- package/inc/util/generic/object_counter.h +0 -53
- package/inc/util/generic/ptr.h +0 -1113
- package/inc/util/generic/queue.h +0 -57
- package/inc/util/generic/refcount.h +0 -162
- package/inc/util/generic/reserve.h +0 -11
- package/inc/util/generic/scope.h +0 -65
- package/inc/util/generic/serialized_enum.h +0 -406
- package/inc/util/generic/set.h +0 -42
- package/inc/util/generic/singleton.h +0 -136
- package/inc/util/generic/size_literals.h +0 -65
- package/inc/util/generic/stack.h +0 -18
- package/inc/util/generic/store_policy.h +0 -120
- package/inc/util/generic/strbase.h +0 -612
- package/inc/util/generic/strbuf.h +0 -552
- package/inc/util/generic/strfcpy.h +0 -17
- package/inc/util/generic/string.h +0 -1572
- package/inc/util/generic/string_hash.h +0 -21
- package/inc/util/generic/string_ut.h +0 -1175
- package/inc/util/generic/type_name.h +0 -34
- package/inc/util/generic/typelist.h +0 -114
- package/inc/util/generic/typetraits.h +0 -325
- package/inc/util/generic/utility.h +0 -132
- package/inc/util/generic/va_args.h +0 -400
- package/inc/util/generic/variant.h +0 -631
- package/inc/util/generic/variant_traits.h +0 -171
- package/inc/util/generic/vector.h +0 -119
- package/inc/util/generic/xrange.h +0 -258
- package/inc/util/generic/yexception.h +0 -212
- package/inc/util/generic/yexception_ut.h +0 -14
- package/inc/util/generic/ylimits.h +0 -92
- package/inc/util/generic/ymath.h +0 -206
- package/inc/util/memory/addstorage.h +0 -93
- package/inc/util/memory/alloc.h +0 -27
- package/inc/util/memory/blob.h +0 -296
- package/inc/util/memory/mmapalloc.h +0 -8
- package/inc/util/memory/pool.h +0 -432
- package/inc/util/memory/segmented_string_pool.h +0 -194
- package/inc/util/memory/segpool_alloc.h +0 -118
- package/inc/util/memory/smallobj.h +0 -141
- package/inc/util/memory/tempbuf.h +0 -111
- package/inc/util/network/address.h +0 -136
- package/inc/util/network/endpoint.h +0 -61
- package/inc/util/network/hostip.h +0 -16
- package/inc/util/network/init.h +0 -60
- package/inc/util/network/interface.h +0 -17
- package/inc/util/network/iovec.h +0 -65
- package/inc/util/network/ip.h +0 -116
- package/inc/util/network/nonblock.h +0 -8
- package/inc/util/network/pair.h +0 -9
- package/inc/util/network/poller.h +0 -58
- package/inc/util/network/pollerimpl.h +0 -707
- package/inc/util/network/sock.h +0 -608
- package/inc/util/network/socket.h +0 -421
- package/inc/util/random/common_ops.h +0 -130
- package/inc/util/random/easy.h +0 -47
- package/inc/util/random/entropy.h +0 -21
- package/inc/util/random/fast.h +0 -101
- package/inc/util/random/init_atfork.h +0 -3
- package/inc/util/random/lcg_engine.h +0 -66
- package/inc/util/random/mersenne.h +0 -46
- package/inc/util/random/mersenne32.h +0 -50
- package/inc/util/random/mersenne64.h +0 -50
- package/inc/util/random/normal.h +0 -38
- package/inc/util/random/random.h +0 -30
- package/inc/util/random/shuffle.h +0 -39
- package/inc/util/str_stl.h +0 -266
- package/inc/util/stream/aligned.h +0 -99
- package/inc/util/stream/buffer.h +0 -119
- package/inc/util/stream/buffered.h +0 -225
- package/inc/util/stream/debug.h +0 -53
- package/inc/util/stream/direct_io.h +0 -43
- package/inc/util/stream/file.h +0 -108
- package/inc/util/stream/format.h +0 -444
- package/inc/util/stream/fwd.h +0 -100
- package/inc/util/stream/hex.h +0 -8
- package/inc/util/stream/holder.h +0 -44
- package/inc/util/stream/input.h +0 -273
- package/inc/util/stream/labeled.h +0 -19
- package/inc/util/stream/length.h +0 -100
- package/inc/util/stream/mem.h +0 -255
- package/inc/util/stream/multi.h +0 -32
- package/inc/util/stream/null.h +0 -61
- package/inc/util/stream/output.h +0 -304
- package/inc/util/stream/pipe.h +0 -112
- package/inc/util/stream/printf.h +0 -25
- package/inc/util/stream/str.h +0 -207
- package/inc/util/stream/tee.h +0 -28
- package/inc/util/stream/tempbuf.h +0 -21
- package/inc/util/stream/tokenizer.h +0 -214
- package/inc/util/stream/trace.h +0 -60
- package/inc/util/stream/walk.h +0 -35
- package/inc/util/stream/zerocopy.h +0 -91
- package/inc/util/stream/zerocopy_output.h +0 -57
- package/inc/util/stream/zlib.h +0 -173
- package/inc/util/string/ascii.h +0 -236
- package/inc/util/string/builder.h +0 -39
- package/inc/util/string/cast.h +0 -347
- package/inc/util/string/cstriter.h +0 -14
- package/inc/util/string/escape.h +0 -70
- package/inc/util/string/hex.h +0 -59
- package/inc/util/string/join.h +0 -194
- package/inc/util/string/printf.h +0 -13
- package/inc/util/string/reverse.h +0 -16
- package/inc/util/string/split.h +0 -1080
- package/inc/util/string/strip.h +0 -257
- package/inc/util/string/strspn.h +0 -65
- package/inc/util/string/subst.h +0 -56
- package/inc/util/string/type.h +0 -50
- package/inc/util/string/util.h +0 -195
- package/inc/util/string/vector.h +0 -132
- package/inc/util/system/align.h +0 -50
- package/inc/util/system/atexit.h +0 -22
- package/inc/util/system/atomic.h +0 -51
- package/inc/util/system/atomic_gcc.h +0 -90
- package/inc/util/system/atomic_ops.h +0 -189
- package/inc/util/system/atomic_win.h +0 -114
- package/inc/util/system/backtrace.h +0 -39
- package/inc/util/system/byteorder.h +0 -186
- package/inc/util/system/compat.h +0 -84
- package/inc/util/system/compiler.h +0 -620
- package/inc/util/system/condvar.h +0 -71
- package/inc/util/system/context.h +0 -181
- package/inc/util/system/context_aarch64.h +0 -8
- package/inc/util/system/context_i686.h +0 -9
- package/inc/util/system/context_x86.h +0 -12
- package/inc/util/system/context_x86_64.h +0 -7
- package/inc/util/system/cpu_id.h +0 -159
- package/inc/util/system/daemon.h +0 -28
- package/inc/util/system/datetime.h +0 -98
- package/inc/util/system/defaults.h +0 -149
- package/inc/util/system/demangle.h +0 -5
- package/inc/util/system/demangle_impl.h +0 -23
- package/inc/util/system/direct_io.h +0 -71
- package/inc/util/system/dynlib.h +0 -119
- package/inc/util/system/env.h +0 -32
- package/inc/util/system/error.h +0 -95
- package/inc/util/system/event.h +0 -122
- package/inc/util/system/execpath.h +0 -17
- package/inc/util/system/fasttime.h +0 -6
- package/inc/util/system/fhandle.h +0 -27
- package/inc/util/system/file.h +0 -210
- package/inc/util/system/file_lock.h +0 -34
- package/inc/util/system/filemap.h +0 -383
- package/inc/util/system/flock.h +0 -35
- package/inc/util/system/fs.h +0 -156
- package/inc/util/system/fs_win.h +0 -29
- package/inc/util/system/fstat.h +0 -46
- package/inc/util/system/getpid.h +0 -12
- package/inc/util/system/guard.h +0 -179
- package/inc/util/system/hi_lo.h +0 -139
- package/inc/util/system/hostname.h +0 -10
- package/inc/util/system/hp_timer.h +0 -36
- package/inc/util/system/info.h +0 -12
- package/inc/util/system/interrupt_signals.h +0 -22
- package/inc/util/system/madvise.h +0 -30
- package/inc/util/system/maxlen.h +0 -32
- package/inc/util/system/mem_info.h +0 -18
- package/inc/util/system/mincore.h +0 -38
- package/inc/util/system/mktemp.h +0 -11
- package/inc/util/system/mlock.h +0 -43
- package/inc/util/system/mutex.h +0 -67
- package/inc/util/system/nice.h +0 -3
- package/inc/util/system/pipe.h +0 -90
- package/inc/util/system/platform.h +0 -246
- package/inc/util/system/progname.h +0 -13
- package/inc/util/system/protect.h +0 -25
- package/inc/util/system/rusage.h +0 -26
- package/inc/util/system/rwlock.h +0 -78
- package/inc/util/system/sanitizers.h +0 -122
- package/inc/util/system/sem.h +0 -41
- package/inc/util/system/shellcommand.h +0 -472
- package/inc/util/system/shmat.h +0 -32
- package/inc/util/system/sigset.h +0 -78
- package/inc/util/system/spin_wait.h +0 -10
- package/inc/util/system/spinlock.h +0 -121
- package/inc/util/system/src_location.h +0 -25
- package/inc/util/system/src_root.h +0 -68
- package/inc/util/system/sys_alloc.h +0 -43
- package/inc/util/system/sysstat.h +0 -52
- package/inc/util/system/tempfile.h +0 -34
- package/inc/util/system/thread.h +0 -167
- package/inc/util/system/tls.h +0 -307
- package/inc/util/system/types.h +0 -119
- package/inc/util/system/unaligned_mem.h +0 -67
- package/inc/util/system/user.h +0 -5
- package/inc/util/system/utime.h +0 -6
- package/inc/util/system/valgrind.h +0 -48
- package/inc/util/system/winint.h +0 -43
- package/inc/util/system/yassert.h +0 -121
- package/inc/util/system/yield.h +0 -4
- package/inc/util/thread/factory.h +0 -65
- package/inc/util/thread/fwd.h +0 -30
- package/inc/util/thread/lfqueue.h +0 -406
- package/inc/util/thread/lfstack.h +0 -188
- package/inc/util/thread/pool.h +0 -388
- package/inc/util/thread/singleton.h +0 -42
- package/inc/util/ysafeptr.h +0 -427
- package/inc/util/ysaveload.h +0 -700
|
@@ -1,765 +0,0 @@
|
|
|
1
|
-
#pragma once
|
|
2
|
-
|
|
3
|
-
#include "is_in.h"
|
|
4
|
-
#include "utility.h"
|
|
5
|
-
|
|
6
|
-
#include <util/system/defaults.h>
|
|
7
|
-
#include <util/generic/fwd.h>
|
|
8
|
-
|
|
9
|
-
#include <numeric>
|
|
10
|
-
#include <algorithm>
|
|
11
|
-
#include <iterator>
|
|
12
|
-
#include <utility>
|
|
13
|
-
|
|
14
|
-
namespace NPrivate {
|
|
15
|
-
template <class I, class F, class P>
|
|
16
|
-
I ExtremeElementBy(I begin, I end, F func, P pred) {
|
|
17
|
-
if (begin == end) {
|
|
18
|
-
return end;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
auto bestValue = func(*begin);
|
|
22
|
-
auto bestPos = begin;
|
|
23
|
-
|
|
24
|
-
for (auto i = ++begin; i != end; ++i) {
|
|
25
|
-
auto curValue = func(*i);
|
|
26
|
-
if (pred(curValue, bestValue)) {
|
|
27
|
-
bestValue = curValue;
|
|
28
|
-
bestPos = i;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
return bestPos;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
template <class T>
|
|
37
|
-
static inline void Sort(T f, T l) {
|
|
38
|
-
std::sort(f, l);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
template <class T, class C>
|
|
42
|
-
static inline void Sort(T f, T l, C c) {
|
|
43
|
-
std::sort(f, l, c);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
template <class TContainer>
|
|
47
|
-
static inline void Sort(TContainer& container) {
|
|
48
|
-
Sort(container.begin(), container.end());
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
template <class TContainer, typename TCompare>
|
|
52
|
-
static inline void Sort(TContainer& container, TCompare compare) {
|
|
53
|
-
Sort(container.begin(), container.end(), compare);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
template <class TIterator, typename TGetKey>
|
|
57
|
-
static inline void SortBy(TIterator begin, TIterator end, const TGetKey& getKey) {
|
|
58
|
-
Sort(begin, end, [&](auto&& left, auto&& right) { return getKey(left) < getKey(right); });
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
template <class TContainer, typename TGetKey>
|
|
62
|
-
static inline void SortBy(TContainer& container, const TGetKey& getKey) {
|
|
63
|
-
SortBy(container.begin(), container.end(), getKey);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
template <class T>
|
|
67
|
-
static inline void StableSort(T f, T l) {
|
|
68
|
-
std::stable_sort(f, l);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
template <class T, class C>
|
|
72
|
-
static inline void StableSort(T f, T l, C c) {
|
|
73
|
-
std::stable_sort(f, l, c);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
template <class TContainer>
|
|
77
|
-
static inline void StableSort(TContainer& container) {
|
|
78
|
-
StableSort(container.begin(), container.end());
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
template <class TContainer, typename TCompare>
|
|
82
|
-
static inline void StableSort(TContainer& container, TCompare compare) {
|
|
83
|
-
StableSort(container.begin(), container.end(), compare);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
template <class TIterator, typename TGetKey>
|
|
87
|
-
static inline void StableSortBy(TIterator begin, TIterator end, const TGetKey& getKey) {
|
|
88
|
-
StableSort(begin, end, [&](auto&& left, auto&& right) { return getKey(left) < getKey(right); });
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
template <class TContainer, typename TGetKey>
|
|
92
|
-
static inline void StableSortBy(TContainer& container, const TGetKey& getKey) {
|
|
93
|
-
StableSortBy(container.begin(), container.end(), getKey);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
template <class T>
|
|
97
|
-
static inline void PartialSort(T f, T m, T l) {
|
|
98
|
-
std::partial_sort(f, m, l);
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
template <class T, class C>
|
|
102
|
-
static inline void PartialSort(T f, T m, T l, C c) {
|
|
103
|
-
std::partial_sort(f, m, l, c);
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
template <class T, class R>
|
|
107
|
-
static inline R PartialSortCopy(T f, T l, R of, R ol) {
|
|
108
|
-
return std::partial_sort_copy(f, l, of, ol);
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
template <class T, class R, class C>
|
|
112
|
-
static inline R PartialSortCopy(T f, T l, R of, R ol, C c) {
|
|
113
|
-
return std::partial_sort_copy(f, l, of, ol, c);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
template <class I, class T>
|
|
117
|
-
static inline I Find(I f, I l, const T& v) {
|
|
118
|
-
return std::find(f, l, v);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
template <class C, class T>
|
|
122
|
-
static inline auto Find(C&& c, const T& v) {
|
|
123
|
-
using std::begin;
|
|
124
|
-
using std::end;
|
|
125
|
-
|
|
126
|
-
return std::find(begin(c), end(c), v);
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
// FindPtr - return NULL if not found. Works for arrays, containers, iterators
|
|
130
|
-
template <class I, class T>
|
|
131
|
-
static inline auto FindPtr(I f, I l, const T& v) -> decltype(&*f) {
|
|
132
|
-
I found = Find(f, l, v);
|
|
133
|
-
return (found != l) ? &*found : nullptr;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
template <class C, class T>
|
|
137
|
-
static inline auto FindPtr(C&& c, const T& v) {
|
|
138
|
-
using std::begin;
|
|
139
|
-
using std::end;
|
|
140
|
-
return FindPtr(begin(c), end(c), v);
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
template <class I, class P>
|
|
144
|
-
static inline I FindIf(I f, I l, P p) {
|
|
145
|
-
return std::find_if(f, l, p);
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
template <class C, class P>
|
|
149
|
-
static inline auto FindIf(C&& c, P p) {
|
|
150
|
-
using std::begin;
|
|
151
|
-
using std::end;
|
|
152
|
-
|
|
153
|
-
return FindIf(begin(c), end(c), p);
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
template <class I, class P>
|
|
157
|
-
static inline bool AllOf(I f, I l, P pred) {
|
|
158
|
-
return std::all_of(f, l, pred);
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
template <class C, class P>
|
|
162
|
-
static inline bool AllOf(const C& c, P pred) {
|
|
163
|
-
using std::begin;
|
|
164
|
-
using std::end;
|
|
165
|
-
return AllOf(begin(c), end(c), pred);
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
template <class I, class P>
|
|
169
|
-
static inline bool AnyOf(I f, I l, P pred) {
|
|
170
|
-
return std::any_of(f, l, pred);
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
template <class C, class P>
|
|
174
|
-
static inline bool AnyOf(const C& c, P pred) {
|
|
175
|
-
using std::begin;
|
|
176
|
-
using std::end;
|
|
177
|
-
return AnyOf(begin(c), end(c), pred);
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
// FindIfPtr - return NULL if not found. Works for arrays, containers, iterators
|
|
181
|
-
template <class I, class P>
|
|
182
|
-
static inline auto FindIfPtr(I f, I l, P pred) -> decltype(&*f) {
|
|
183
|
-
I found = FindIf(f, l, pred);
|
|
184
|
-
return (found != l) ? &*found : nullptr;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
template <class C, class P>
|
|
188
|
-
static inline auto FindIfPtr(C&& c, P pred) {
|
|
189
|
-
using std::begin;
|
|
190
|
-
using std::end;
|
|
191
|
-
return FindIfPtr(begin(c), end(c), pred);
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
template <class C, class T>
|
|
195
|
-
static inline size_t FindIndex(C&& c, const T& x) {
|
|
196
|
-
using std::begin;
|
|
197
|
-
using std::end;
|
|
198
|
-
auto it = Find(begin(c), end(c), x);
|
|
199
|
-
return it == end(c) ? NPOS : (it - begin(c));
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
template <class C, class P>
|
|
203
|
-
static inline size_t FindIndexIf(C&& c, P p) {
|
|
204
|
-
using std::begin;
|
|
205
|
-
using std::end;
|
|
206
|
-
auto it = FindIf(begin(c), end(c), p);
|
|
207
|
-
return it == end(c) ? NPOS : (it - begin(c));
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
//EqualToOneOf(x, "apple", "orange") means (x == "apple" || x == "orange")
|
|
211
|
-
template <typename T>
|
|
212
|
-
inline bool EqualToOneOf(const T&) {
|
|
213
|
-
return false;
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
template <typename T, typename U, typename... Other>
|
|
217
|
-
inline bool EqualToOneOf(const T& x, const U& y, const Other&... other) {
|
|
218
|
-
return x == y || EqualToOneOf(x, other...);
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
template <typename T>
|
|
222
|
-
static inline size_t CountOf(const T&) {
|
|
223
|
-
return 0;
|
|
224
|
-
}
|
|
225
|
-
|
|
226
|
-
template <typename T, typename U, typename... Other>
|
|
227
|
-
static inline size_t CountOf(const T& x, const U& y, const Other&... other) {
|
|
228
|
-
return static_cast<size_t>(x == y) + CountOf(x, other...);
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
template <class I>
|
|
232
|
-
static inline void PushHeap(I f, I l) {
|
|
233
|
-
std::push_heap(f, l);
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
template <class I, class C>
|
|
237
|
-
static inline void PushHeap(I f, I l, C c) {
|
|
238
|
-
std::push_heap(f, l, c);
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
template <class I>
|
|
242
|
-
static inline void PopHeap(I f, I l) {
|
|
243
|
-
std::pop_heap(f, l);
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
template <class I, class C>
|
|
247
|
-
static inline void PopHeap(I f, I l, C c) {
|
|
248
|
-
std::pop_heap(f, l, c);
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
template <class I>
|
|
252
|
-
static inline void MakeHeap(I f, I l) {
|
|
253
|
-
std::make_heap(f, l);
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
template <class I, class C>
|
|
257
|
-
static inline void MakeHeap(I f, I l, C c) {
|
|
258
|
-
std::make_heap(f, l, c);
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
template <class I>
|
|
262
|
-
static inline void SortHeap(I f, I l) {
|
|
263
|
-
std::sort_heap(f, l);
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
template <class I, class C>
|
|
267
|
-
static inline void SortHeap(I f, I l, C c) {
|
|
268
|
-
std::sort_heap(f, l, c);
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
template <class I, class T>
|
|
272
|
-
static inline I LowerBound(I f, I l, const T& v) {
|
|
273
|
-
return std::lower_bound(f, l, v);
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
template <class I, class T, class C>
|
|
277
|
-
static inline I LowerBound(I f, I l, const T& v, C c) {
|
|
278
|
-
return std::lower_bound(f, l, v, c);
|
|
279
|
-
}
|
|
280
|
-
|
|
281
|
-
template <class I, class T, class TGetKey>
|
|
282
|
-
static inline I LowerBoundBy(I f, I l, const T& v, const TGetKey& getKey) {
|
|
283
|
-
return std::lower_bound(f, l, v, [&](auto&& left, auto&& right) { return getKey(left) < right; });
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
template <class I, class T>
|
|
287
|
-
static inline I UpperBound(I f, I l, const T& v) {
|
|
288
|
-
return std::upper_bound(f, l, v);
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
template <class I, class T, class C>
|
|
292
|
-
static inline I UpperBound(I f, I l, const T& v, C c) {
|
|
293
|
-
return std::upper_bound(f, l, v, c);
|
|
294
|
-
}
|
|
295
|
-
|
|
296
|
-
template <class I, class T, class TGetKey>
|
|
297
|
-
static inline I UpperBoundBy(I f, I l, const T& v, const TGetKey& getKey) {
|
|
298
|
-
return std::upper_bound(f, l, v, [&](auto&& left, auto&& right) { return left < getKey(right); });
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
template <class T>
|
|
302
|
-
static inline T Unique(T f, T l) {
|
|
303
|
-
return std::unique(f, l);
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
template <class T, class P>
|
|
307
|
-
static inline T Unique(T f, T l, P p) {
|
|
308
|
-
return std::unique(f, l, p);
|
|
309
|
-
}
|
|
310
|
-
|
|
311
|
-
template <class T, class TGetKey>
|
|
312
|
-
static inline T UniqueBy(T f, T l, const TGetKey& getKey) {
|
|
313
|
-
return Unique(f, l, [&](auto&& left, auto&& right) { return getKey(left) == getKey(right); });
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
template <class C>
|
|
317
|
-
void SortUnique(C& c) {
|
|
318
|
-
Sort(c.begin(), c.end());
|
|
319
|
-
c.erase(Unique(c.begin(), c.end()), c.end());
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
template <class C, class Cmp>
|
|
323
|
-
void SortUnique(C& c, Cmp cmp) {
|
|
324
|
-
Sort(c.begin(), c.end(), cmp);
|
|
325
|
-
c.erase(Unique(c.begin(), c.end()), c.end());
|
|
326
|
-
}
|
|
327
|
-
|
|
328
|
-
template <class C, class TGetKey>
|
|
329
|
-
void SortUniqueBy(C& c, const TGetKey& getKey) {
|
|
330
|
-
SortBy(c, getKey);
|
|
331
|
-
c.erase(UniqueBy(c.begin(), c.end(), getKey), c.end());
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
template <class C, class TGetKey>
|
|
335
|
-
void StableSortUniqueBy(C& c, const TGetKey& getKey) {
|
|
336
|
-
StableSortBy(c, getKey);
|
|
337
|
-
c.erase(UniqueBy(c.begin(), c.end(), getKey), c.end());
|
|
338
|
-
}
|
|
339
|
-
|
|
340
|
-
template <class C, class TValue>
|
|
341
|
-
void Erase(C& c, const TValue& value) {
|
|
342
|
-
c.erase(std::remove(c.begin(), c.end(), value), c.end());
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
template <class C, class P>
|
|
346
|
-
void EraseIf(C& c, P p) {
|
|
347
|
-
c.erase(std::remove_if(c.begin(), c.end(), p), c.end());
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
template <class C, class P>
|
|
351
|
-
void EraseNodesIf(C& c, P p) {
|
|
352
|
-
for (auto iter = c.begin(), last = c.end(); iter != last;) {
|
|
353
|
-
if (p(*iter)) {
|
|
354
|
-
c.erase(iter++);
|
|
355
|
-
} else {
|
|
356
|
-
++iter;
|
|
357
|
-
}
|
|
358
|
-
}
|
|
359
|
-
}
|
|
360
|
-
|
|
361
|
-
template <class T1, class T2>
|
|
362
|
-
static inline bool Equal(T1 f1, T1 l1, T2 f2) {
|
|
363
|
-
return std::equal(f1, l1, f2);
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
template <class T1, class T2, class P>
|
|
367
|
-
static inline bool Equal(T1 f1, T1 l1, T2 f2, P p) {
|
|
368
|
-
return std::equal(f1, l1, f2, p);
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
template <class TI, class TO>
|
|
372
|
-
static inline TO Copy(TI f, TI l, TO t) {
|
|
373
|
-
return std::copy(f, l, t);
|
|
374
|
-
}
|
|
375
|
-
|
|
376
|
-
template <class TI, class TO>
|
|
377
|
-
static inline TO UniqueCopy(TI f, TI l, TO t) {
|
|
378
|
-
return std::unique_copy(f, l, t);
|
|
379
|
-
}
|
|
380
|
-
|
|
381
|
-
template <class TI, class TO, class TP>
|
|
382
|
-
static inline TO UniqueCopy(TI f, TI l, TO t, TP p) {
|
|
383
|
-
return std::unique_copy(f, l, t, p);
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
template <class TI, class TO, class TP>
|
|
387
|
-
static inline TO RemoveCopyIf(TI f, TI l, TO t, TP p) {
|
|
388
|
-
return std::remove_copy_if(f, l, t, p);
|
|
389
|
-
}
|
|
390
|
-
|
|
391
|
-
template <class TI, class TO>
|
|
392
|
-
static inline TO ReverseCopy(TI f, TI l, TO t) {
|
|
393
|
-
return std::reverse_copy(f, l, t);
|
|
394
|
-
}
|
|
395
|
-
|
|
396
|
-
template <class TI1, class TI2, class TO>
|
|
397
|
-
static inline TO SetUnion(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p) {
|
|
398
|
-
return std::set_union(f1, l1, f2, l2, p);
|
|
399
|
-
}
|
|
400
|
-
|
|
401
|
-
template <class TI1, class TI2, class TO, class TC>
|
|
402
|
-
static inline TO SetUnion(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p, TC c) {
|
|
403
|
-
return std::set_union(f1, l1, f2, l2, p, c);
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
template <class TI1, class TI2, class TO>
|
|
407
|
-
static inline TO SetDifference(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p) {
|
|
408
|
-
return std::set_difference(f1, l1, f2, l2, p);
|
|
409
|
-
}
|
|
410
|
-
|
|
411
|
-
template <class TI1, class TI2, class TO, class TC>
|
|
412
|
-
static inline TO SetDifference(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p, TC c) {
|
|
413
|
-
return std::set_difference(f1, l1, f2, l2, p, c);
|
|
414
|
-
}
|
|
415
|
-
|
|
416
|
-
template <class TI1, class TI2, class TO>
|
|
417
|
-
static inline TO SetSymmetricDifference(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p) {
|
|
418
|
-
return std::set_symmetric_difference(f1, l1, f2, l2, p);
|
|
419
|
-
}
|
|
420
|
-
|
|
421
|
-
template <class TI1, class TI2, class TO, class TC>
|
|
422
|
-
static inline TO SetSymmetricDifference(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p, TC c) {
|
|
423
|
-
return std::set_symmetric_difference(f1, l1, f2, l2, p, c);
|
|
424
|
-
}
|
|
425
|
-
|
|
426
|
-
template <class TI1, class TI2, class TO>
|
|
427
|
-
static inline TO SetIntersection(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p) {
|
|
428
|
-
return std::set_intersection(f1, l1, f2, l2, p);
|
|
429
|
-
}
|
|
430
|
-
|
|
431
|
-
template <class TI1, class TI2, class TO, class TC>
|
|
432
|
-
static inline TO SetIntersection(TI1 f1, TI1 l1, TI2 f2, TI2 l2, TO p, TC c) {
|
|
433
|
-
return std::set_intersection(f1, l1, f2, l2, p, c);
|
|
434
|
-
}
|
|
435
|
-
|
|
436
|
-
template <class I, class T>
|
|
437
|
-
static inline void Fill(I f, I l, const T& v) {
|
|
438
|
-
std::fill(f, l, v);
|
|
439
|
-
}
|
|
440
|
-
|
|
441
|
-
template <typename I, typename S, typename T>
|
|
442
|
-
static inline I FillN(I f, S n, const T& v) {
|
|
443
|
-
return std::fill_n(f, n, v);
|
|
444
|
-
}
|
|
445
|
-
|
|
446
|
-
template <class T>
|
|
447
|
-
static inline void Reverse(T f, T l) {
|
|
448
|
-
std::reverse(f, l);
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
template <class T>
|
|
452
|
-
static inline void Rotate(T f, T m, T l) {
|
|
453
|
-
std::rotate(f, m, l);
|
|
454
|
-
}
|
|
455
|
-
|
|
456
|
-
template <typename It, typename Val>
|
|
457
|
-
Val Accumulate(It begin, It end, Val val) {
|
|
458
|
-
// std::move since C++20
|
|
459
|
-
return std::accumulate(begin, end, std::move(val));
|
|
460
|
-
}
|
|
461
|
-
|
|
462
|
-
template <typename It, typename Val, typename BinOp>
|
|
463
|
-
Val Accumulate(It begin, It end, Val val, BinOp binOp) {
|
|
464
|
-
// std::move since C++20
|
|
465
|
-
return std::accumulate(begin, end, std::move(val), binOp);
|
|
466
|
-
}
|
|
467
|
-
|
|
468
|
-
template <typename C, typename Val>
|
|
469
|
-
Val Accumulate(const C& c, Val val) {
|
|
470
|
-
// std::move since C++20
|
|
471
|
-
return Accumulate(std::begin(c), std::end(c), std::move(val));
|
|
472
|
-
}
|
|
473
|
-
|
|
474
|
-
template <typename C, typename Val, typename BinOp>
|
|
475
|
-
Val Accumulate(const C& c, Val val, BinOp binOp) {
|
|
476
|
-
// std::move since C++20
|
|
477
|
-
return Accumulate(std::begin(c), std::end(c), std::move(val), binOp);
|
|
478
|
-
}
|
|
479
|
-
|
|
480
|
-
template <typename It1, typename It2, typename Val>
|
|
481
|
-
static inline Val InnerProduct(It1 begin1, It1 end1, It2 begin2, Val val) {
|
|
482
|
-
return std::inner_product(begin1, end1, begin2, val);
|
|
483
|
-
}
|
|
484
|
-
|
|
485
|
-
template <typename It1, typename It2, typename Val, typename BinOp1, typename BinOp2>
|
|
486
|
-
static inline Val InnerProduct(It1 begin1, It1 end1, It2 begin2, Val val, BinOp1 binOp1, BinOp2 binOp2) {
|
|
487
|
-
return std::inner_product(begin1, end1, begin2, val, binOp1, binOp2);
|
|
488
|
-
}
|
|
489
|
-
|
|
490
|
-
template <typename TVectorType>
|
|
491
|
-
static inline typename TVectorType::value_type InnerProduct(const TVectorType& lhs, const TVectorType& rhs, typename TVectorType::value_type val = typename TVectorType::value_type()) {
|
|
492
|
-
return std::inner_product(lhs.begin(), lhs.end(), rhs.begin(), val);
|
|
493
|
-
}
|
|
494
|
-
|
|
495
|
-
template <typename TVectorType, typename BinOp1, typename BinOp2>
|
|
496
|
-
static inline typename TVectorType::value_type InnerProduct(const TVectorType& lhs, const TVectorType& rhs, typename TVectorType::value_type val, BinOp1 binOp1, BinOp2 binOp2) {
|
|
497
|
-
return std::inner_product(lhs.begin(), lhs.end(), rhs.begin(), val, binOp1, binOp2);
|
|
498
|
-
}
|
|
499
|
-
|
|
500
|
-
template <class T>
|
|
501
|
-
static inline T MinElement(T begin, T end) {
|
|
502
|
-
return std::min_element(begin, end);
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
template <class T, class C>
|
|
506
|
-
static inline T MinElement(T begin, T end, C comp) {
|
|
507
|
-
return std::min_element(begin, end, comp);
|
|
508
|
-
}
|
|
509
|
-
|
|
510
|
-
template <class T>
|
|
511
|
-
static inline T MaxElement(T begin, T end) {
|
|
512
|
-
return std::max_element(begin, end);
|
|
513
|
-
}
|
|
514
|
-
|
|
515
|
-
template <class T, class C>
|
|
516
|
-
static inline T MaxElement(T begin, T end, C comp) {
|
|
517
|
-
return std::max_element(begin, end, comp);
|
|
518
|
-
}
|
|
519
|
-
|
|
520
|
-
template <class I, class F>
|
|
521
|
-
I MaxElementBy(I begin, I end, F&& func) {
|
|
522
|
-
using TValue = decltype(func(*begin));
|
|
523
|
-
return ::NPrivate::ExtremeElementBy(begin, end, std::forward<F>(func), TGreater<TValue>());
|
|
524
|
-
}
|
|
525
|
-
|
|
526
|
-
template <class C, class F>
|
|
527
|
-
auto MaxElementBy(C& c, F&& func) {
|
|
528
|
-
return MaxElementBy(std::begin(c), std::end(c), std::forward<F>(func));
|
|
529
|
-
}
|
|
530
|
-
|
|
531
|
-
template <class C, class F>
|
|
532
|
-
auto MaxElementBy(const C& c, F&& func) {
|
|
533
|
-
return MaxElementBy(std::begin(c), std::end(c), std::forward<F>(func));
|
|
534
|
-
}
|
|
535
|
-
|
|
536
|
-
template <class I, class F>
|
|
537
|
-
I MinElementBy(I begin, I end, F&& func) {
|
|
538
|
-
using TValue = decltype(func(*begin));
|
|
539
|
-
return ::NPrivate::ExtremeElementBy(begin, end, std::forward<F>(func), TLess<TValue>());
|
|
540
|
-
}
|
|
541
|
-
|
|
542
|
-
template <class C, class F>
|
|
543
|
-
auto MinElementBy(C& c, F&& func) {
|
|
544
|
-
return MinElementBy(std::begin(c), std::end(c), std::forward<F>(func));
|
|
545
|
-
}
|
|
546
|
-
|
|
547
|
-
template <class C, class F>
|
|
548
|
-
auto MinElementBy(const C& c, F&& func) {
|
|
549
|
-
return MinElementBy(std::begin(c), std::end(c), std::forward<F>(func));
|
|
550
|
-
}
|
|
551
|
-
|
|
552
|
-
template <class TOp, class... TArgs>
|
|
553
|
-
void ApplyToMany(TOp op, TArgs&&... args) {
|
|
554
|
-
int dummy[] = {((void)op(std::forward<TArgs>(args)), 0)...};
|
|
555
|
-
Y_UNUSED(dummy);
|
|
556
|
-
}
|
|
557
|
-
|
|
558
|
-
template <class TI, class TOp>
|
|
559
|
-
inline void ForEach(TI f, TI l, TOp op) {
|
|
560
|
-
std::for_each(f, l, op);
|
|
561
|
-
}
|
|
562
|
-
|
|
563
|
-
namespace NPrivate {
|
|
564
|
-
template <class T, class TOp, size_t... Is>
|
|
565
|
-
constexpr bool AllOfImpl(T&& t, TOp&& op, std::index_sequence<Is...>) {
|
|
566
|
-
#if _LIBCPP_STD_VER >= 17
|
|
567
|
-
return (true && ... && op(std::get<Is>(std::forward<T>(t))));
|
|
568
|
-
#else
|
|
569
|
-
bool result = true;
|
|
570
|
-
auto wrapper = [&result, &op](auto&& x) { result = result && op(std::forward<decltype(x)>(x)); };
|
|
571
|
-
int dummy[] = {(wrapper(std::get<Is>(std::forward<T>(t))), 0)...};
|
|
572
|
-
Y_UNUSED(dummy);
|
|
573
|
-
return result;
|
|
574
|
-
#endif
|
|
575
|
-
}
|
|
576
|
-
|
|
577
|
-
template <class T, class TOp, size_t... Is>
|
|
578
|
-
constexpr bool AnyOfImpl(T&& t, TOp&& op, std::index_sequence<Is...>) {
|
|
579
|
-
#if _LIBCPP_STD_VER >= 17
|
|
580
|
-
return (false || ... || op(std::get<Is>(std::forward<T>(t))));
|
|
581
|
-
#else
|
|
582
|
-
bool result = false;
|
|
583
|
-
auto wrapper = [&result, &op](auto&& x) { result = result || op(std::forward<decltype(x)>(x)); };
|
|
584
|
-
int dummy[] = {(wrapper(std::get<Is>(std::forward<T>(t))), 0)...};
|
|
585
|
-
Y_UNUSED(dummy);
|
|
586
|
-
return result;
|
|
587
|
-
#endif
|
|
588
|
-
}
|
|
589
|
-
|
|
590
|
-
template <class T, class TOp, size_t... Is>
|
|
591
|
-
constexpr void ForEachImpl(T&& t, TOp&& op, std::index_sequence<Is...>) {
|
|
592
|
-
#if _LIBCPP_STD_VER >= 17
|
|
593
|
-
(..., op(std::get<Is>(std::forward<T>(t))));
|
|
594
|
-
#else
|
|
595
|
-
::ApplyToMany(std::forward<TOp>(op), std::get<Is>(std::forward<T>(t))...);
|
|
596
|
-
#endif
|
|
597
|
-
}
|
|
598
|
-
}
|
|
599
|
-
|
|
600
|
-
// check that TOp return true for all of element from tuple T
|
|
601
|
-
template <class T, class TOp>
|
|
602
|
-
constexpr ::TEnableIfTuple<T, bool> AllOf(T&& t, TOp&& op) {
|
|
603
|
-
return ::NPrivate::AllOfImpl(
|
|
604
|
-
std::forward<T>(t),
|
|
605
|
-
std::forward<TOp>(op),
|
|
606
|
-
std::make_index_sequence<std::tuple_size<std::decay_t<T>>::value>{});
|
|
607
|
-
}
|
|
608
|
-
|
|
609
|
-
// check that TOp return true for at least one element from tuple T
|
|
610
|
-
template <class T, class TOp>
|
|
611
|
-
constexpr ::TEnableIfTuple<T, bool> AnyOf(T&& t, TOp&& op) {
|
|
612
|
-
return ::NPrivate::AnyOfImpl(
|
|
613
|
-
std::forward<T>(t),
|
|
614
|
-
std::forward<TOp>(op),
|
|
615
|
-
std::make_index_sequence<std::tuple_size<std::decay_t<T>>::value>{});
|
|
616
|
-
}
|
|
617
|
-
|
|
618
|
-
template <class T, class TOp>
|
|
619
|
-
constexpr ::TEnableIfTuple<T> ForEach(T&& t, TOp&& op) {
|
|
620
|
-
::NPrivate::ForEachImpl(
|
|
621
|
-
std::forward<T>(t),
|
|
622
|
-
std::forward<TOp>(op),
|
|
623
|
-
std::make_index_sequence<std::tuple_size<std::decay_t<T>>::value>{});
|
|
624
|
-
}
|
|
625
|
-
|
|
626
|
-
template <class T1, class T2, class O>
|
|
627
|
-
static inline void Transform(T1 b, T1 e, T2 o, O f) {
|
|
628
|
-
std::transform(b, e, o, f);
|
|
629
|
-
}
|
|
630
|
-
|
|
631
|
-
template <class T1, class T2, class T3, class O>
|
|
632
|
-
static inline void Transform(T1 b1, T1 e1, T2 b2, T3 o, O f) {
|
|
633
|
-
std::transform(b1, e1, b2, o, f);
|
|
634
|
-
}
|
|
635
|
-
|
|
636
|
-
template <class T, class V>
|
|
637
|
-
inline typename std::iterator_traits<T>::difference_type Count(T first, T last, const V& value) {
|
|
638
|
-
return std::count(first, last, value);
|
|
639
|
-
}
|
|
640
|
-
|
|
641
|
-
template <class TContainer, class TValue>
|
|
642
|
-
static inline auto Count(const TContainer& container, const TValue& value) {
|
|
643
|
-
return Count(std::cbegin(container), std::cend(container), value);
|
|
644
|
-
}
|
|
645
|
-
|
|
646
|
-
template <class It, class P>
|
|
647
|
-
static inline auto CountIf(It first, It last, P p) {
|
|
648
|
-
return std::count_if(first, last, p);
|
|
649
|
-
}
|
|
650
|
-
|
|
651
|
-
template <class C, class P>
|
|
652
|
-
static inline auto CountIf(const C& c, P pred) {
|
|
653
|
-
using std::begin;
|
|
654
|
-
using std::end;
|
|
655
|
-
return CountIf(begin(c), end(c), pred);
|
|
656
|
-
}
|
|
657
|
-
|
|
658
|
-
template <class I1, class I2>
|
|
659
|
-
static inline std::pair<I1, I2> Mismatch(I1 b1, I1 e1, I2 b2) {
|
|
660
|
-
return std::mismatch(b1, e1, b2);
|
|
661
|
-
}
|
|
662
|
-
|
|
663
|
-
template <class I1, class I2, class P>
|
|
664
|
-
static inline std::pair<I1, I2> Mismatch(I1 b1, I1 e1, I2 b2, P p) {
|
|
665
|
-
return std::mismatch(b1, e1, b2, p);
|
|
666
|
-
}
|
|
667
|
-
|
|
668
|
-
template <class RandomIterator>
|
|
669
|
-
static inline void NthElement(RandomIterator begin, RandomIterator nth, RandomIterator end) {
|
|
670
|
-
std::nth_element(begin, nth, end);
|
|
671
|
-
}
|
|
672
|
-
|
|
673
|
-
template <class RandomIterator, class Compare>
|
|
674
|
-
static inline void NthElement(RandomIterator begin, RandomIterator nth, RandomIterator end, Compare compare) {
|
|
675
|
-
std::nth_element(begin, nth, end, compare);
|
|
676
|
-
}
|
|
677
|
-
|
|
678
|
-
// no standard implementation until C++14
|
|
679
|
-
template <class I1, class I2>
|
|
680
|
-
static inline std::pair<I1, I2> Mismatch(I1 b1, I1 e1, I2 b2, I2 e2) {
|
|
681
|
-
while (b1 != e1 && b2 != e2 && *b1 == *b2) {
|
|
682
|
-
++b1;
|
|
683
|
-
++b2;
|
|
684
|
-
}
|
|
685
|
-
return std::make_pair(b1, b2);
|
|
686
|
-
}
|
|
687
|
-
|
|
688
|
-
template <class I1, class I2, class P>
|
|
689
|
-
static inline std::pair<I1, I2> Mismatch(I1 b1, I1 e1, I2 b2, I2 e2, P p) {
|
|
690
|
-
while (b1 != e1 && b2 != e2 && p(*b1, *b2)) {
|
|
691
|
-
++b1;
|
|
692
|
-
++b2;
|
|
693
|
-
}
|
|
694
|
-
return std::make_pair(b1, b2);
|
|
695
|
-
}
|
|
696
|
-
|
|
697
|
-
template <class It, class Val>
|
|
698
|
-
static inline bool BinarySearch(It begin, It end, const Val& val) {
|
|
699
|
-
return std::binary_search(begin, end, val);
|
|
700
|
-
}
|
|
701
|
-
|
|
702
|
-
template <class It, class Val, class Comp>
|
|
703
|
-
static inline bool BinarySearch(It begin, It end, const Val& val, Comp comp) {
|
|
704
|
-
return std::binary_search(begin, end, val, comp);
|
|
705
|
-
}
|
|
706
|
-
|
|
707
|
-
template <class It, class Val>
|
|
708
|
-
static inline std::pair<It, It> EqualRange(It begin, It end, const Val& val) {
|
|
709
|
-
return std::equal_range(begin, end, val);
|
|
710
|
-
}
|
|
711
|
-
|
|
712
|
-
template <class It, class Val, class Comp>
|
|
713
|
-
static inline std::pair<It, It> EqualRange(It begin, It end, const Val& val, Comp comp) {
|
|
714
|
-
return std::equal_range(begin, end, val, comp);
|
|
715
|
-
}
|
|
716
|
-
|
|
717
|
-
template <class ForwardIt>
|
|
718
|
-
bool IsSorted(ForwardIt begin, ForwardIt end) {
|
|
719
|
-
return std::is_sorted(begin, end);
|
|
720
|
-
}
|
|
721
|
-
|
|
722
|
-
template <class ForwardIt, class Compare>
|
|
723
|
-
bool IsSorted(ForwardIt begin, ForwardIt end, Compare comp) {
|
|
724
|
-
return std::is_sorted(begin, end, comp);
|
|
725
|
-
}
|
|
726
|
-
|
|
727
|
-
template <class TIterator, typename TGetKey>
|
|
728
|
-
bool IsSortedBy(TIterator begin, TIterator end, const TGetKey& getKey) {
|
|
729
|
-
return IsSorted(begin, end, [&](auto&& left, auto&& right) { return getKey(left) < getKey(right); });
|
|
730
|
-
}
|
|
731
|
-
|
|
732
|
-
template <class It, class Val>
|
|
733
|
-
void Iota(It begin, It end, Val val) {
|
|
734
|
-
std::iota(begin, end, val);
|
|
735
|
-
}
|
|
736
|
-
|
|
737
|
-
template <class TI, class TO, class S>
|
|
738
|
-
TO CopyN(TI from, S s, TO to) {
|
|
739
|
-
return std::copy_n(from, s, to);
|
|
740
|
-
}
|
|
741
|
-
|
|
742
|
-
template <class TI, class TO, class P>
|
|
743
|
-
TO CopyIf(TI begin, TI end, TO to, P pred) {
|
|
744
|
-
return std::copy_if(begin, end, to, pred);
|
|
745
|
-
}
|
|
746
|
-
|
|
747
|
-
template <class T>
|
|
748
|
-
std::pair<const T&, const T&> MinMax(const T& first, const T& second) {
|
|
749
|
-
return std::minmax(first, second);
|
|
750
|
-
}
|
|
751
|
-
|
|
752
|
-
template <class It>
|
|
753
|
-
std::pair<It, It> MinMaxElement(It first, It last) {
|
|
754
|
-
return std::minmax_element(first, last);
|
|
755
|
-
}
|
|
756
|
-
|
|
757
|
-
template <class TIterator, class TGenerator>
|
|
758
|
-
void Generate(TIterator first, TIterator last, TGenerator generator) {
|
|
759
|
-
std::generate(first, last, generator);
|
|
760
|
-
}
|
|
761
|
-
|
|
762
|
-
template <class TIterator, class TSize, class TGenerator>
|
|
763
|
-
void GenerateN(TIterator first, TSize count, TGenerator generator) {
|
|
764
|
-
std::generate_n(first, count, generator);
|
|
765
|
-
}
|