的一种方法是使用dot-product
与2-powered
范围阵列 -
b.dot(2**np.arange(b.size)[::-1])
采样运行 -
In [95]: b = np.array([1,0,1,0,0,0,0,0,1,0,1])
In [96]: b.dot(2**np.arange(b.size)[::-1])
Out[96]: 1285
或者,我们可以使用按位左移运算符来创建范围阵列,从而得到所需的输出像这样 -
b.dot(1 << np.arange(b.size)[::-1])
如果定时感兴趣 -
In [148]: b = np.random.randint(0,2,(50))
In [149]: %timeit b.dot(2**np.arange(b.size)[::-1])
100000 loops, best of 3: 13.1 µs per loop
In [150]: %timeit b.dot(1 << np.arange(b.size)[::-1])
100000 loops, best of 3: 7.92 µs per loop
逆过程
要检索回二进制数组,使用np.binary_repr
非常久远np.fromstring
-
In [96]: b = np.array([1,0,1,0,0,0,0,0,1,0,1])
In [97]: num = b.dot(2**np.arange(b.size)[::-1]) # integer
In [98]: np.fromstring(np.binary_repr(num), dtype='S1').astype(int)
Out[98]: array([1, 0, 1, 0, 0, 0, 0, 0, 1, 0, 1])
聪明:)如果有人能想出更好的办法......在我批准之前,将等待一两天。 – user1019129
任何建议转换回原来的二进制数组格式? – Jonathan
@Jonathan好问题!应该早些加入。发布。 – Divakar