[RISCV] Fix mgather -> riscv.masked.strided.load combine not extending indices (...
[llvm-project.git] / libcxx / src / hash.cpp
blob34b02b8eafc21feb43a44511f597a7a58137a6f7
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
9 #include <__hash_table>
10 #include <algorithm>
11 #include <stdexcept>
12 #include <type_traits>
14 _LIBCPP_CLANG_DIAGNOSTIC_IGNORED("-Wtautological-constant-out-of-range-compare")
16 _LIBCPP_BEGIN_NAMESPACE_STD
18 namespace {
20 // handle all next_prime(i) for i in [1, 210), special case 0
21 const unsigned small_primes[] = {
22 0, 2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47,
23 53, 59, 61, 67, 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 127,
24 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199, 211};
26 // potential primes = 210*k + indices[i], k >= 1
27 // these numbers are not divisible by 2, 3, 5 or 7
28 // (or any integer 2 <= j <= 10 for that matter).
29 const unsigned indices[] = {
30 1, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67,
31 71, 73, 79, 83, 89, 97, 101, 103, 107, 109, 113, 121, 127, 131, 137, 139,
32 143, 149, 151, 157, 163, 167, 169, 173, 179, 181, 187, 191, 193, 197, 199, 209};
34 } // namespace
36 // Returns: If n == 0, returns 0. Else returns the lowest prime number that
37 // is greater than or equal to n.
39 // The algorithm creates a list of small primes, plus an open-ended list of
40 // potential primes. All prime numbers are potential prime numbers. However
41 // some potential prime numbers are not prime. In an ideal world, all potential
42 // prime numbers would be prime. Candidate prime numbers are chosen as the next
43 // highest potential prime. Then this number is tested for prime by dividing it
44 // by all potential prime numbers less than the sqrt of the candidate.
46 // This implementation defines potential primes as those numbers not divisible
47 // by 2, 3, 5, and 7. Other (common) implementations define potential primes
48 // as those not divisible by 2. A few other implementations define potential
49 // primes as those not divisible by 2 or 3. By raising the number of small
50 // primes which the potential prime is not divisible by, the set of potential
51 // primes more closely approximates the set of prime numbers. And thus there
52 // are fewer potential primes to search, and fewer potential primes to divide
53 // against.
55 template <size_t _Sz = sizeof(size_t)>
56 inline _LIBCPP_HIDE_FROM_ABI typename enable_if<_Sz == 4, void>::type __check_for_overflow(size_t N) {
57 if (N > 0xFFFFFFFB)
58 __throw_overflow_error("__next_prime overflow");
61 template <size_t _Sz = sizeof(size_t)>
62 inline _LIBCPP_HIDE_FROM_ABI typename enable_if<_Sz == 8, void>::type __check_for_overflow(size_t N) {
63 if (N > 0xFFFFFFFFFFFFFFC5ull)
64 __throw_overflow_error("__next_prime overflow");
67 size_t __next_prime(size_t n) {
68 const size_t L = 210;
69 const size_t N = sizeof(small_primes) / sizeof(small_primes[0]);
70 // If n is small enough, search in small_primes
71 if (n <= small_primes[N - 1])
72 return *std::lower_bound(small_primes, small_primes + N, n);
73 // Else n > largest small_primes
74 // Check for overflow
75 __check_for_overflow(n);
76 // Start searching list of potential primes: L * k0 + indices[in]
77 const size_t M = sizeof(indices) / sizeof(indices[0]);
78 // Select first potential prime >= n
79 // Known a-priori n >= L
80 size_t k0 = n / L;
81 size_t in = static_cast<size_t>(std::lower_bound(indices, indices + M, n - k0 * L) - indices);
82 n = L * k0 + indices[in];
83 while (true) {
84 // Divide n by all primes or potential primes (i) until:
85 // 1. The division is even, so try next potential prime.
86 // 2. The i > sqrt(n), in which case n is prime.
87 // It is known a-priori that n is not divisible by 2, 3, 5 or 7,
88 // so don't test those (j == 5 -> divide by 11 first). And the
89 // potential primes start with 211, so don't test against the last
90 // small prime.
91 for (size_t j = 5; j < N - 1; ++j) {
92 const std::size_t p = small_primes[j];
93 const std::size_t q = n / p;
94 if (q < p)
95 return n;
96 if (n == q * p)
97 goto next;
99 // n wasn't divisible by small primes, try potential primes
101 size_t i = 211;
102 while (true) {
103 std::size_t q = n / i;
104 if (q < i)
105 return n;
106 if (n == q * i)
107 break;
109 i += 10;
110 q = n / i;
111 if (q < i)
112 return n;
113 if (n == q * i)
114 break;
116 i += 2;
117 q = n / i;
118 if (q < i)
119 return n;
120 if (n == q * i)
121 break;
123 i += 4;
124 q = n / i;
125 if (q < i)
126 return n;
127 if (n == q * i)
128 break;
130 i += 2;
131 q = n / i;
132 if (q < i)
133 return n;
134 if (n == q * i)
135 break;
137 i += 4;
138 q = n / i;
139 if (q < i)
140 return n;
141 if (n == q * i)
142 break;
144 i += 6;
145 q = n / i;
146 if (q < i)
147 return n;
148 if (n == q * i)
149 break;
151 i += 2;
152 q = n / i;
153 if (q < i)
154 return n;
155 if (n == q * i)
156 break;
158 i += 6;
159 q = n / i;
160 if (q < i)
161 return n;
162 if (n == q * i)
163 break;
165 i += 4;
166 q = n / i;
167 if (q < i)
168 return n;
169 if (n == q * i)
170 break;
172 i += 2;
173 q = n / i;
174 if (q < i)
175 return n;
176 if (n == q * i)
177 break;
179 i += 4;
180 q = n / i;
181 if (q < i)
182 return n;
183 if (n == q * i)
184 break;
186 i += 6;
187 q = n / i;
188 if (q < i)
189 return n;
190 if (n == q * i)
191 break;
193 i += 6;
194 q = n / i;
195 if (q < i)
196 return n;
197 if (n == q * i)
198 break;
200 i += 2;
201 q = n / i;
202 if (q < i)
203 return n;
204 if (n == q * i)
205 break;
207 i += 6;
208 q = n / i;
209 if (q < i)
210 return n;
211 if (n == q * i)
212 break;
214 i += 4;
215 q = n / i;
216 if (q < i)
217 return n;
218 if (n == q * i)
219 break;
221 i += 2;
222 q = n / i;
223 if (q < i)
224 return n;
225 if (n == q * i)
226 break;
228 i += 6;
229 q = n / i;
230 if (q < i)
231 return n;
232 if (n == q * i)
233 break;
235 i += 4;
236 q = n / i;
237 if (q < i)
238 return n;
239 if (n == q * i)
240 break;
242 i += 6;
243 q = n / i;
244 if (q < i)
245 return n;
246 if (n == q * i)
247 break;
249 i += 8;
250 q = n / i;
251 if (q < i)
252 return n;
253 if (n == q * i)
254 break;
256 i += 4;
257 q = n / i;
258 if (q < i)
259 return n;
260 if (n == q * i)
261 break;
263 i += 2;
264 q = n / i;
265 if (q < i)
266 return n;
267 if (n == q * i)
268 break;
270 i += 4;
271 q = n / i;
272 if (q < i)
273 return n;
274 if (n == q * i)
275 break;
277 i += 2;
278 q = n / i;
279 if (q < i)
280 return n;
281 if (n == q * i)
282 break;
284 i += 4;
285 q = n / i;
286 if (q < i)
287 return n;
288 if (n == q * i)
289 break;
291 i += 8;
292 q = n / i;
293 if (q < i)
294 return n;
295 if (n == q * i)
296 break;
298 i += 6;
299 q = n / i;
300 if (q < i)
301 return n;
302 if (n == q * i)
303 break;
305 i += 4;
306 q = n / i;
307 if (q < i)
308 return n;
309 if (n == q * i)
310 break;
312 i += 6;
313 q = n / i;
314 if (q < i)
315 return n;
316 if (n == q * i)
317 break;
319 i += 2;
320 q = n / i;
321 if (q < i)
322 return n;
323 if (n == q * i)
324 break;
326 i += 4;
327 q = n / i;
328 if (q < i)
329 return n;
330 if (n == q * i)
331 break;
333 i += 6;
334 q = n / i;
335 if (q < i)
336 return n;
337 if (n == q * i)
338 break;
340 i += 2;
341 q = n / i;
342 if (q < i)
343 return n;
344 if (n == q * i)
345 break;
347 i += 6;
348 q = n / i;
349 if (q < i)
350 return n;
351 if (n == q * i)
352 break;
354 i += 6;
355 q = n / i;
356 if (q < i)
357 return n;
358 if (n == q * i)
359 break;
361 i += 4;
362 q = n / i;
363 if (q < i)
364 return n;
365 if (n == q * i)
366 break;
368 i += 2;
369 q = n / i;
370 if (q < i)
371 return n;
372 if (n == q * i)
373 break;
375 i += 4;
376 q = n / i;
377 if (q < i)
378 return n;
379 if (n == q * i)
380 break;
382 i += 6;
383 q = n / i;
384 if (q < i)
385 return n;
386 if (n == q * i)
387 break;
389 i += 2;
390 q = n / i;
391 if (q < i)
392 return n;
393 if (n == q * i)
394 break;
396 i += 6;
397 q = n / i;
398 if (q < i)
399 return n;
400 if (n == q * i)
401 break;
403 i += 4;
404 q = n / i;
405 if (q < i)
406 return n;
407 if (n == q * i)
408 break;
410 i += 2;
411 q = n / i;
412 if (q < i)
413 return n;
414 if (n == q * i)
415 break;
417 i += 4;
418 q = n / i;
419 if (q < i)
420 return n;
421 if (n == q * i)
422 break;
424 i += 2;
425 q = n / i;
426 if (q < i)
427 return n;
428 if (n == q * i)
429 break;
431 i += 10;
432 q = n / i;
433 if (q < i)
434 return n;
435 if (n == q * i)
436 break;
438 // This will loop i to the next "plane" of potential primes
439 i += 2;
442 next:
443 // n is not prime. Increment n to next potential prime.
444 if (++in == M) {
445 ++k0;
446 in = 0;
448 n = L * k0 + indices[in];
452 _LIBCPP_END_NAMESPACE_STD