Commit cd2ebf9
authored
And similarly for `randcycle` and `shuffle`.
We had a custom version of range generation for `randperm`, which was
based on the ideas of our previous default range sampler
`SamplerRangeFast` (generate `k`-bits integers using masking and reject
out-of-range ones) and took advantage of the fact that `randperm` needs
to generate `rand(1:i)` for `i = 2:n`.
But our current range sampler ("Nearly Division Less") is usually better
than this hack, and makes these functions more readable. Typically, for
array lengths `< 2^20`, the new version is faster, but gets slightly
slower beyond 2^22.
Here are some speedups:

The slow down for big arrays seems fine to me, but I will see if I can
find an easy workaround.
Fix #57771.
1 parent 0f9b2fc commit cd2ebf9
1 file changed
+39
-59
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
176 | 176 | | |
177 | 177 | | |
178 | 178 | | |
179 | | - | |
180 | | - | |
181 | | - | |
182 | | - | |
183 | | - | |
184 | 179 | | |
185 | 180 | | |
186 | 181 | | |
| |||
219 | 214 | | |
220 | 215 | | |
221 | 216 | | |
222 | | - | |
223 | | - | |
224 | | - | |
225 | | - | |
226 | | - | |
227 | | - | |
228 | | - | |
229 | | - | |
230 | | - | |
231 | | - | |
232 | | - | |
233 | | - | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
234 | 225 | | |
235 | 226 | | |
236 | | - | |
| 227 | + | |
237 | 228 | | |
238 | 229 | | |
239 | | - | |
240 | | - | |
241 | | - | |
242 | | - | |
243 | | - | |
244 | | - | |
| 230 | + | |
| 231 | + | |
245 | 232 | | |
246 | | - | |
247 | 233 | | |
248 | 234 | | |
249 | 235 | | |
| |||
278 | 264 | | |
279 | 265 | | |
280 | 266 | | |
281 | | - | |
282 | | - | |
283 | | - | |
284 | | - | |
285 | | - | |
286 | | - | |
287 | | - | |
288 | | - | |
289 | | - | |
290 | | - | |
291 | | - | |
292 | | - | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
293 | 275 | | |
294 | 276 | | |
295 | 277 | | |
| |||
318 | 300 | | |
319 | 301 | | |
320 | 302 | | |
321 | | - | |
322 | | - | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
323 | 306 | | |
324 | | - | |
325 | 307 | | |
| 308 | + | |
326 | 309 | | |
| 310 | + | |
327 | 311 | | |
328 | 312 | | |
329 | 313 | | |
| |||
342 | 326 | | |
343 | 327 | | |
344 | 328 | | |
345 | | - | |
346 | | - | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
347 | 332 | | |
348 | | - | |
349 | 333 | | |
| 334 | + | |
350 | 335 | | |
| 336 | + | |
351 | 337 | | |
352 | 338 | | |
353 | | - | |
| 339 | + | |
354 | 340 | | |
355 | 341 | | |
356 | 342 | | |
357 | | - | |
358 | 343 | | |
359 | 344 | | |
360 | | - | |
361 | 345 | | |
362 | | - | |
| 346 | + | |
363 | 347 | | |
364 | 348 | | |
365 | 349 | | |
366 | 350 | | |
367 | | - | |
368 | 351 | | |
369 | 352 | | |
370 | 353 | | |
| |||
393 | 376 | | |
394 | 377 | | |
395 | 378 | | |
396 | | - | |
| 379 | + | |
397 | 380 | | |
398 | 381 | | |
| 382 | + | |
399 | 383 | | |
400 | | - | |
401 | 384 | | |
402 | 385 | | |
403 | | - | |
| 386 | + | |
404 | 387 | | |
405 | 388 | | |
406 | 389 | | |
| |||
424 | 407 | | |
425 | 408 | | |
426 | 409 | | |
427 | | - | |
| 410 | + | |
428 | 411 | | |
429 | 412 | | |
| 413 | + | |
430 | 414 | | |
431 | | - | |
432 | 415 | | |
433 | 416 | | |
434 | | - | |
| 417 | + | |
435 | 418 | | |
436 | 419 | | |
437 | | - | |
| 420 | + | |
438 | 421 | | |
439 | 422 | | |
440 | 423 | | |
441 | | - | |
442 | 424 | | |
443 | 425 | | |
444 | | - | |
445 | 426 | | |
446 | 427 | | |
447 | | - | |
| 428 | + | |
448 | 429 | | |
449 | 430 | | |
450 | | - | |
451 | 431 | | |
452 | 432 | | |
453 | 433 | | |
| |||
0 commit comments