Libraryless. Click here for Pure Java version (10297L/57K).
1 | // Allows to vary the order by supplying a seed |
2 | // |
3 | // We add the seed to every LSFR value generated, and also start |
4 | // the LSFR with the seed. |
5 | |
6 | // Not 100% sure if this works, there was an endless loop once |
7 | |
8 | sclass WeightlessShuffledIteratorWithSeed<A> extends WeightlessShuffledIterator<A> {
|
9 | final int offset; |
10 | |
11 | // initialize only with a length (and a pseudo-list) |
12 | // if you are going to be calling nextIndex() instead of next() |
13 | *(int n) {
|
14 | this((L) iotaZeroList(n)); |
15 | } |
16 | |
17 | *(int n, int seed) {
|
18 | this((L) iotaZeroList(n), seed); |
19 | } |
20 | |
21 | *(L<A> list) {
|
22 | this(list, 0); |
23 | } |
24 | |
25 | *(L<A> list, int seed) {
|
26 | super(list); |
27 | if (n == 0) ret with offset = 0; |
28 | lsfr_start(seed); |
29 | offset = value-1; |
30 | } |
31 | |
32 | // copied from TripletLSFR.start |
33 | void lsfr_start(int seed) {
|
34 | value = mod_31bit(seed, cycleLength)+1; |
35 | } |
36 | |
37 | int postProcessLSFRValue(int i) {
|
38 | i += offset; |
39 | ret i >= cycleLength ? i-cycleLength : i; |
40 | } |
41 | } |
Began life as a copy of #1035206
download show line numbers debug dex old transpilations
Travelled to 4 computer(s): bhatertpkbcr, ekrmjmnbrukm, mowyntqkapby, mqqgnosmbjvj
No comments. add comment
| Snippet ID: | #1035207 |
| Snippet name: | WeightlessShuffledIteratorWithSeed |
| Eternal ID of this version: | #1035207/22 |
| Text MD5: | 75e1a03cd9a68794e5df4083cdd65fd1 |
| Transpilation MD5: | 060a0a397b6ae576669c992dea9956b7 |
| Author: | stefan |
| Category: | javax |
| Type: | JavaX fragment (include) |
| Public (visible to everyone): | Yes |
| Archived (hidden from active list): | No |
| Created/modified: | 2023-02-12 14:45:18 |
| Source code size: | 988 bytes / 41 lines |
| Pitched / IR pitched: | No / No |
| Views / Downloads: | 699 / 964 |
| Version history: | 21 change(s) |
| Referenced in: | [show references] |