我有许多需要大量随机数数组的 SIMD 风格的并行应用程序。这些数组是“分布式数组”,在多个任务和节点之间共享,具有重叠以支持空间运算符。我需要的是一个随机数生成器,它将在多个线程上给出与在一个线程上相同的结果。我可以使用一个简单的版本,其中所有任务都查询一个主任务,但我们会失去可伸缩性。
总而言之,我想要一个可扩展的并行随机数生成器,它提供与使用主任务提供所有数字相同的结果。
提前感谢您的任何建议!
查克
PS 这是一个简单的序列化版本,我想用可扩展的实现来替换它:
import java.util.Random;
public class ParallelRandom {
int size; // Number of tasks in the parallel context
int rank; // Rank of this task in the parallel context
Random r; // Random number generator used by master task
public ParallelRandom( int numTasks, int taskRank, long seed ) {
// Store size and rank
size = numTasks;
rank = taskRank;
// initialize Random
r = new Random(seed);
}
// Public method that must be called synchronously by all tasks
public void nextRandomVector( double[] vector ) {
int len = vector.length;
// Loop over all tasks in the context
for (int itask=0; itask<size; itask++) {
// Set the return values for this task, otherwise just advance the random number
if (rank == itask)
for (int i=0; i<len; i++)
vector[i] = r.nextGaussian();
else
for (int i=0; i<len; i++)
r.nextGaussian();
}
}
}