catboost 1.25.1 → 1.27.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.
Files changed (290) hide show
  1. package/DEPLOYMENT.md +22 -15
  2. package/README.md +43 -27
  3. package/binding.gyp +5 -7
  4. package/build_scripts/bootstrap.js +2 -1
  5. package/build_scripts/out/build.js +46 -68
  6. package/build_scripts/out/build_model.js +1 -1
  7. package/build_scripts/out/{build_ya.js → build_native.js} +1 -1
  8. package/build_scripts/out/ci.js +5 -5
  9. package/build_scripts/out/common.js +1 -1
  10. package/build_scripts/out/config.js +32 -18
  11. package/build_scripts/out/install.js +5 -3
  12. package/build_scripts/out/package_prepublish.js +1 -1
  13. package/build_scripts/out/packaging.js +1 -19
  14. package/build_scripts/out/run_tests.js +1 -1
  15. package/build_scripts/out/test.js +8 -3
  16. package/config.json +18 -11
  17. package/inc/catboost/libs/model_interface/c_api.h +367 -5
  18. package/lib/catboost.d.ts +65 -21
  19. package/package.json +4 -4
  20. package/src/api_helpers.cpp +100 -24
  21. package/src/api_helpers.h +8 -7
  22. package/src/api_module.cpp +1 -2
  23. package/src/model.cpp +483 -83
  24. package/src/model.h +24 -9
  25. package/inc/contrib/libs/cxxsupp/system_stl/include/stlfwd +0 -14
  26. package/inc/util/charset/recode_result.h +0 -9
  27. package/inc/util/charset/unicode_table.h +0 -123
  28. package/inc/util/charset/unidata.h +0 -421
  29. package/inc/util/charset/utf8.h +0 -384
  30. package/inc/util/charset/wide.h +0 -843
  31. package/inc/util/charset/wide_specific.h +0 -22
  32. package/inc/util/datetime/base.h +0 -669
  33. package/inc/util/datetime/constants.h +0 -7
  34. package/inc/util/datetime/cputimer.h +0 -124
  35. package/inc/util/datetime/parser.h +0 -292
  36. package/inc/util/datetime/systime.h +0 -47
  37. package/inc/util/datetime/uptime.h +0 -8
  38. package/inc/util/digest/city.h +0 -88
  39. package/inc/util/digest/fnv.h +0 -73
  40. package/inc/util/digest/multi.h +0 -14
  41. package/inc/util/digest/murmur.h +0 -57
  42. package/inc/util/digest/numeric.h +0 -86
  43. package/inc/util/digest/sequence.h +0 -48
  44. package/inc/util/draft/date.h +0 -129
  45. package/inc/util/draft/datetime.h +0 -184
  46. package/inc/util/draft/enum.h +0 -136
  47. package/inc/util/draft/holder_vector.h +0 -102
  48. package/inc/util/draft/ip.h +0 -131
  49. package/inc/util/draft/matrix.h +0 -108
  50. package/inc/util/draft/memory.h +0 -40
  51. package/inc/util/folder/dirent_win.h +0 -46
  52. package/inc/util/folder/dirut.h +0 -121
  53. package/inc/util/folder/filelist.h +0 -81
  54. package/inc/util/folder/fts.h +0 -108
  55. package/inc/util/folder/iterator.h +0 -109
  56. package/inc/util/folder/lstat_win.h +0 -20
  57. package/inc/util/folder/path.h +0 -225
  58. package/inc/util/folder/pathsplit.h +0 -113
  59. package/inc/util/folder/tempdir.h +0 -42
  60. package/inc/util/generic/adaptor.h +0 -134
  61. package/inc/util/generic/algorithm.h +0 -765
  62. package/inc/util/generic/array_ref.h +0 -282
  63. package/inc/util/generic/array_size.h +0 -24
  64. package/inc/util/generic/benchmark/vector_count_ctor/f.h +0 -9
  65. package/inc/util/generic/bitmap.h +0 -1115
  66. package/inc/util/generic/bitops.h +0 -459
  67. package/inc/util/generic/bt_exception.h +0 -24
  68. package/inc/util/generic/buffer.h +0 -232
  69. package/inc/util/generic/cast.h +0 -176
  70. package/inc/util/generic/deque.h +0 -24
  71. package/inc/util/generic/explicit_type.h +0 -42
  72. package/inc/util/generic/fastqueue.h +0 -55
  73. package/inc/util/generic/flags.h +0 -244
  74. package/inc/util/generic/function.h +0 -103
  75. package/inc/util/generic/fwd.h +0 -171
  76. package/inc/util/generic/guid.h +0 -61
  77. package/inc/util/generic/hash.h +0 -2032
  78. package/inc/util/generic/hash_primes.h +0 -140
  79. package/inc/util/generic/hash_set.h +0 -490
  80. package/inc/util/generic/hide_ptr.h +0 -3
  81. package/inc/util/generic/intrlist.h +0 -876
  82. package/inc/util/generic/is_in.h +0 -53
  83. package/inc/util/generic/iterator.h +0 -137
  84. package/inc/util/generic/iterator_range.h +0 -105
  85. package/inc/util/generic/lazy_value.h +0 -66
  86. package/inc/util/generic/list.h +0 -22
  87. package/inc/util/generic/map.h +0 -44
  88. package/inc/util/generic/mapfindptr.h +0 -60
  89. package/inc/util/generic/maybe.h +0 -713
  90. package/inc/util/generic/maybe_traits.h +0 -164
  91. package/inc/util/generic/mem_copy.h +0 -55
  92. package/inc/util/generic/noncopyable.h +0 -38
  93. package/inc/util/generic/object_counter.h +0 -53
  94. package/inc/util/generic/ptr.h +0 -1113
  95. package/inc/util/generic/queue.h +0 -57
  96. package/inc/util/generic/refcount.h +0 -162
  97. package/inc/util/generic/reserve.h +0 -11
  98. package/inc/util/generic/scope.h +0 -65
  99. package/inc/util/generic/serialized_enum.h +0 -406
  100. package/inc/util/generic/set.h +0 -42
  101. package/inc/util/generic/singleton.h +0 -136
  102. package/inc/util/generic/size_literals.h +0 -65
  103. package/inc/util/generic/stack.h +0 -18
  104. package/inc/util/generic/store_policy.h +0 -120
  105. package/inc/util/generic/strbase.h +0 -612
  106. package/inc/util/generic/strbuf.h +0 -552
  107. package/inc/util/generic/strfcpy.h +0 -17
  108. package/inc/util/generic/string.h +0 -1572
  109. package/inc/util/generic/string_hash.h +0 -21
  110. package/inc/util/generic/string_ut.h +0 -1175
  111. package/inc/util/generic/type_name.h +0 -34
  112. package/inc/util/generic/typelist.h +0 -114
  113. package/inc/util/generic/typetraits.h +0 -325
  114. package/inc/util/generic/utility.h +0 -132
  115. package/inc/util/generic/va_args.h +0 -400
  116. package/inc/util/generic/variant.h +0 -631
  117. package/inc/util/generic/variant_traits.h +0 -171
  118. package/inc/util/generic/vector.h +0 -119
  119. package/inc/util/generic/xrange.h +0 -258
  120. package/inc/util/generic/yexception.h +0 -212
  121. package/inc/util/generic/yexception_ut.h +0 -14
  122. package/inc/util/generic/ylimits.h +0 -92
  123. package/inc/util/generic/ymath.h +0 -206
  124. package/inc/util/memory/addstorage.h +0 -93
  125. package/inc/util/memory/alloc.h +0 -27
  126. package/inc/util/memory/blob.h +0 -296
  127. package/inc/util/memory/mmapalloc.h +0 -8
  128. package/inc/util/memory/pool.h +0 -432
  129. package/inc/util/memory/segmented_string_pool.h +0 -194
  130. package/inc/util/memory/segpool_alloc.h +0 -118
  131. package/inc/util/memory/smallobj.h +0 -141
  132. package/inc/util/memory/tempbuf.h +0 -111
  133. package/inc/util/network/address.h +0 -136
  134. package/inc/util/network/endpoint.h +0 -61
  135. package/inc/util/network/hostip.h +0 -16
  136. package/inc/util/network/init.h +0 -60
  137. package/inc/util/network/interface.h +0 -17
  138. package/inc/util/network/iovec.h +0 -65
  139. package/inc/util/network/ip.h +0 -116
  140. package/inc/util/network/nonblock.h +0 -8
  141. package/inc/util/network/pair.h +0 -9
  142. package/inc/util/network/poller.h +0 -58
  143. package/inc/util/network/pollerimpl.h +0 -707
  144. package/inc/util/network/sock.h +0 -608
  145. package/inc/util/network/socket.h +0 -421
  146. package/inc/util/random/common_ops.h +0 -130
  147. package/inc/util/random/easy.h +0 -47
  148. package/inc/util/random/entropy.h +0 -21
  149. package/inc/util/random/fast.h +0 -101
  150. package/inc/util/random/init_atfork.h +0 -3
  151. package/inc/util/random/lcg_engine.h +0 -66
  152. package/inc/util/random/mersenne.h +0 -46
  153. package/inc/util/random/mersenne32.h +0 -50
  154. package/inc/util/random/mersenne64.h +0 -50
  155. package/inc/util/random/normal.h +0 -38
  156. package/inc/util/random/random.h +0 -30
  157. package/inc/util/random/shuffle.h +0 -39
  158. package/inc/util/str_stl.h +0 -266
  159. package/inc/util/stream/aligned.h +0 -99
  160. package/inc/util/stream/buffer.h +0 -119
  161. package/inc/util/stream/buffered.h +0 -225
  162. package/inc/util/stream/debug.h +0 -53
  163. package/inc/util/stream/direct_io.h +0 -43
  164. package/inc/util/stream/file.h +0 -108
  165. package/inc/util/stream/format.h +0 -444
  166. package/inc/util/stream/fwd.h +0 -100
  167. package/inc/util/stream/hex.h +0 -8
  168. package/inc/util/stream/holder.h +0 -44
  169. package/inc/util/stream/input.h +0 -273
  170. package/inc/util/stream/labeled.h +0 -19
  171. package/inc/util/stream/length.h +0 -100
  172. package/inc/util/stream/mem.h +0 -255
  173. package/inc/util/stream/multi.h +0 -32
  174. package/inc/util/stream/null.h +0 -61
  175. package/inc/util/stream/output.h +0 -304
  176. package/inc/util/stream/pipe.h +0 -112
  177. package/inc/util/stream/printf.h +0 -25
  178. package/inc/util/stream/str.h +0 -207
  179. package/inc/util/stream/tee.h +0 -28
  180. package/inc/util/stream/tempbuf.h +0 -21
  181. package/inc/util/stream/tokenizer.h +0 -214
  182. package/inc/util/stream/trace.h +0 -60
  183. package/inc/util/stream/walk.h +0 -35
  184. package/inc/util/stream/zerocopy.h +0 -91
  185. package/inc/util/stream/zerocopy_output.h +0 -57
  186. package/inc/util/stream/zlib.h +0 -173
  187. package/inc/util/string/ascii.h +0 -236
  188. package/inc/util/string/builder.h +0 -39
  189. package/inc/util/string/cast.h +0 -347
  190. package/inc/util/string/cstriter.h +0 -14
  191. package/inc/util/string/escape.h +0 -70
  192. package/inc/util/string/hex.h +0 -59
  193. package/inc/util/string/join.h +0 -194
  194. package/inc/util/string/printf.h +0 -13
  195. package/inc/util/string/reverse.h +0 -16
  196. package/inc/util/string/split.h +0 -1080
  197. package/inc/util/string/strip.h +0 -257
  198. package/inc/util/string/strspn.h +0 -65
  199. package/inc/util/string/subst.h +0 -56
  200. package/inc/util/string/type.h +0 -50
  201. package/inc/util/string/util.h +0 -195
  202. package/inc/util/string/vector.h +0 -132
  203. package/inc/util/system/align.h +0 -50
  204. package/inc/util/system/atexit.h +0 -22
  205. package/inc/util/system/atomic.h +0 -51
  206. package/inc/util/system/atomic_gcc.h +0 -90
  207. package/inc/util/system/atomic_ops.h +0 -189
  208. package/inc/util/system/atomic_win.h +0 -114
  209. package/inc/util/system/backtrace.h +0 -39
  210. package/inc/util/system/byteorder.h +0 -186
  211. package/inc/util/system/compat.h +0 -84
  212. package/inc/util/system/compiler.h +0 -620
  213. package/inc/util/system/condvar.h +0 -71
  214. package/inc/util/system/context.h +0 -181
  215. package/inc/util/system/context_aarch64.h +0 -8
  216. package/inc/util/system/context_i686.h +0 -9
  217. package/inc/util/system/context_x86.h +0 -12
  218. package/inc/util/system/context_x86_64.h +0 -7
  219. package/inc/util/system/cpu_id.h +0 -159
  220. package/inc/util/system/daemon.h +0 -28
  221. package/inc/util/system/datetime.h +0 -98
  222. package/inc/util/system/defaults.h +0 -149
  223. package/inc/util/system/demangle.h +0 -5
  224. package/inc/util/system/demangle_impl.h +0 -23
  225. package/inc/util/system/direct_io.h +0 -71
  226. package/inc/util/system/dynlib.h +0 -119
  227. package/inc/util/system/env.h +0 -32
  228. package/inc/util/system/error.h +0 -95
  229. package/inc/util/system/event.h +0 -122
  230. package/inc/util/system/execpath.h +0 -17
  231. package/inc/util/system/fasttime.h +0 -6
  232. package/inc/util/system/fhandle.h +0 -27
  233. package/inc/util/system/file.h +0 -210
  234. package/inc/util/system/file_lock.h +0 -34
  235. package/inc/util/system/filemap.h +0 -383
  236. package/inc/util/system/flock.h +0 -35
  237. package/inc/util/system/fs.h +0 -156
  238. package/inc/util/system/fs_win.h +0 -29
  239. package/inc/util/system/fstat.h +0 -46
  240. package/inc/util/system/getpid.h +0 -12
  241. package/inc/util/system/guard.h +0 -179
  242. package/inc/util/system/hi_lo.h +0 -139
  243. package/inc/util/system/hostname.h +0 -10
  244. package/inc/util/system/hp_timer.h +0 -36
  245. package/inc/util/system/info.h +0 -12
  246. package/inc/util/system/interrupt_signals.h +0 -22
  247. package/inc/util/system/madvise.h +0 -30
  248. package/inc/util/system/maxlen.h +0 -32
  249. package/inc/util/system/mem_info.h +0 -18
  250. package/inc/util/system/mincore.h +0 -38
  251. package/inc/util/system/mktemp.h +0 -11
  252. package/inc/util/system/mlock.h +0 -43
  253. package/inc/util/system/mutex.h +0 -67
  254. package/inc/util/system/nice.h +0 -3
  255. package/inc/util/system/pipe.h +0 -90
  256. package/inc/util/system/platform.h +0 -246
  257. package/inc/util/system/progname.h +0 -13
  258. package/inc/util/system/protect.h +0 -25
  259. package/inc/util/system/rusage.h +0 -26
  260. package/inc/util/system/rwlock.h +0 -78
  261. package/inc/util/system/sanitizers.h +0 -122
  262. package/inc/util/system/sem.h +0 -41
  263. package/inc/util/system/shellcommand.h +0 -472
  264. package/inc/util/system/shmat.h +0 -32
  265. package/inc/util/system/sigset.h +0 -78
  266. package/inc/util/system/spin_wait.h +0 -10
  267. package/inc/util/system/spinlock.h +0 -121
  268. package/inc/util/system/src_location.h +0 -25
  269. package/inc/util/system/src_root.h +0 -68
  270. package/inc/util/system/sys_alloc.h +0 -43
  271. package/inc/util/system/sysstat.h +0 -52
  272. package/inc/util/system/tempfile.h +0 -34
  273. package/inc/util/system/thread.h +0 -167
  274. package/inc/util/system/tls.h +0 -307
  275. package/inc/util/system/types.h +0 -119
  276. package/inc/util/system/unaligned_mem.h +0 -67
  277. package/inc/util/system/user.h +0 -5
  278. package/inc/util/system/utime.h +0 -6
  279. package/inc/util/system/valgrind.h +0 -48
  280. package/inc/util/system/winint.h +0 -43
  281. package/inc/util/system/yassert.h +0 -121
  282. package/inc/util/system/yield.h +0 -4
  283. package/inc/util/thread/factory.h +0 -65
  284. package/inc/util/thread/fwd.h +0 -30
  285. package/inc/util/thread/lfqueue.h +0 -406
  286. package/inc/util/thread/lfstack.h +0 -188
  287. package/inc/util/thread/pool.h +0 -388
  288. package/inc/util/thread/singleton.h +0 -42
  289. package/inc/util/ysafeptr.h +0 -427
  290. 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
- }