Numpy:生成 2 个无重叠的 n 个随机数序列
Numpy: Generate 2 sequences of n random numbers with no overlaps
对于 n = 5
,[0, 2] 中的两个随机整数序列可能如下所示:
l1 = [2, 0, 2, 2, 0]
l2 = [0, 1, 2, 2, 2]
我想确保 l1[i] != l2[i]
对所有 i
。我当前的方法(遍历所有值并替换重叠部分)似乎很笨拙:
n = 5
sample = np.arange(3)
l1 = np.random.choice(sample, size=n)
l2 = np.random.choice(sample, size=n)
mask = np.ones(sample.size, dtype=bool)
for i in xrange(n):
if l1[i] == l2[i]:
mask[l1[i]] = False
l2[i] = np.random.choice(sample[mask])
mask[l1[i]] = True
有更好的方法吗?
一种方法是像您一样计算 l1
,然后计算每个元素的一组距离或偏移量,并确保偏移量不能为 0:
ofs = l2 = np.random.choice(sample[:-1], size=n)+1
然后您可以将这些偏移量添加到 l1
并将结果换回范围:
l2 = (l1 + ofs) % (sample[-1] + 1)
对于 n = 5
,[0, 2] 中的两个随机整数序列可能如下所示:
l1 = [2, 0, 2, 2, 0]
l2 = [0, 1, 2, 2, 2]
我想确保 l1[i] != l2[i]
对所有 i
。我当前的方法(遍历所有值并替换重叠部分)似乎很笨拙:
n = 5
sample = np.arange(3)
l1 = np.random.choice(sample, size=n)
l2 = np.random.choice(sample, size=n)
mask = np.ones(sample.size, dtype=bool)
for i in xrange(n):
if l1[i] == l2[i]:
mask[l1[i]] = False
l2[i] = np.random.choice(sample[mask])
mask[l1[i]] = True
有更好的方法吗?
一种方法是像您一样计算 l1
,然后计算每个元素的一组距离或偏移量,并确保偏移量不能为 0:
ofs = l2 = np.random.choice(sample[:-1], size=n)+1
然后您可以将这些偏移量添加到 l1
并将结果换回范围:
l2 = (l1 + ofs) % (sample[-1] + 1)