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