📄 randombucketorder.java
字号:
package org.sunflow.core.bucket;
import org.sunflow.core.BucketOrder;
public class RandomBucketOrder implements BucketOrder {
public int[] getBucketSequence(int nbw, int nbh) {
int[] coords = new int[2 * nbw * nbh];
for (int i = 0; i < nbw * nbh; i++) {
int by = i / nbw;
int bx = i % nbw;
if ((by & 1) == 1)
bx = nbw - 1 - bx;
coords[2 * i + 0] = bx;
coords[2 * i + 1] = by;
}
long seed = 2463534242L;
for (int i = 0; i < coords.length; i++) {
// pick 2 random indices
seed = xorshift(seed);
int src = mod((int) seed, nbw * nbh);
seed = xorshift(seed);
int dst = mod((int) seed, nbw * nbh);
int tmp = coords[2 * src + 0];
coords[2 * src + 0] = coords[2 * dst + 0];
coords[2 * dst + 0] = tmp;
tmp = coords[2 * src + 1];
coords[2 * src + 1] = coords[2 * dst + 1];
coords[2 * dst + 1] = tmp;
}
return coords;
}
private int mod(int a, int b) {
int m = a % b;
return (m < 0) ? m + b : m;
}
private long xorshift(long y) {
y = y ^ (y << 13);
y = y ^ (y >>> 17); // unsigned
y = y ^ (y << 5);
return y;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -