python - 在 numpy 中向前和向后位扫描

标签 python numpy binary bitboard

我需要计算 numpy uint64 变量中尾随零和前导零的数量,所以现在我这样做:

# n > 0
n = np.uint64(100)
s = np.binary_repr(n)
trail_zeros = len(s) - len(s.rstrip('0'))
lead_zeros = 64 - len(s)

有没有不使用字符串的更好方法? 优先考虑的是速度。谢谢!

最佳答案

对于 [0,2**63) 中的数字,我们可以使用一些算术运算来获取二进制格式的前导和尾随零,从而跳过字符串操作 -

def get_leading_trailing_zeros(n):
    a = (2**np.arange(64) & n)
    lead_zeros = 64-a.argmax()-1
    if n==0:
        trail_zeros = 1
    else:
        trail_zeros = (a==0).argmin()
    return lead_zeros,trail_zeros

关于python - 在 numpy 中向前和向后位扫描,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55009983/

相关文章:

python - 将列表列表转换为数据框中的列

python - 如何从元组列表中删除项目?

c++ - Boost Binary Endian 解析器不工作?

java - 使用 JAI 将 JAVA 中的二进制文本转换为 Tiff 图像/PDF

python - Sentry 与 Mongodb 兼容吗?

python - 终止无限循环的线程应用程序

python - Pandas 数据框的自定义函数中的 Forex_python

python - scipy hierarchy.linkage 和 Bray-Curtis 距离不一致

python - PCA、truncated_svd 和 svds 在 numpy 和 sklearn 上的不同结果

php - PHP 的 hex2bin 函数的 ColdFusion 替代方案