- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试使用 numpy 将几个掩码( bool 数组)转换为一个位掩码,虽然理论上可行,但我觉得我做了太多操作。
例如创建我使用的位掩码:
import numpy as np
flags = [
np.array([True, False, False]),
np.array([False, True, False]),
np.array([False, True, False])
]
flag_bits = np.zeros(3, dtype=np.int8)
for idx, flag in enumerate(flags):
flag_bits += flag.astype(np.int8) << idx # equivalent to flag * 2 ** idx
这给了我预期的“位掩码”:
>>> flag_bits
array([1, 6, 0], dtype=int8)
>>> [np.binary_repr(bit, width=7) for bit in flag_bits]
['0000001', '0000110', '0000000']
但是我觉得特别是 int8
的转换和 flag_bits
数组的加法太复杂了。因此,我想问一下,是否有任何我遗漏的 NumPy 功能可用于创建这样的“位掩码”数组?
注意:我正在调用一个需要这样一个位掩码的外部函数,否则我会坚持使用 bool 数组。
最佳答案
>>> x = np.array(2**i for i in range(1, np.shape(flags)[1]+1))
>>> np.dot(flags, x)
array([1, 2, 2])
工作原理:在位掩码中,每一位实际上都是原始数组元素根据其位置乘以 2 的次数,例如4 = 假 * 1 + 真 * 2 + 假 * 4
。实际上,这可以表示为矩阵乘法,这在 numpy 中非常有效。
因此,第一行是创建这些权重的列表理解:x = [1, 2, 4, 8, ... 2^(n+1)]。
然后,flags 中的每一行都乘以 x 中的相应元素,然后将所有内容相加(这就是矩阵乘法的工作原理)。最后,我们得到位掩码
关于python - 从几个 bool numpy 数组创建 "bitmask",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42058057/
关于 PHP documentation关于 JSON,它提到了位掩码这个词。维基百科将其定义为面具。我不明白位掩码或掩码或它们是如何有用的。有人可以使用外行的术语而不是行话来解释这些术语吗? 最佳答
阅读销售点系统的文档,这里是他们给出的 mask 示例,该 mask 应该告诉您选择了哪些座位。我无法弄清楚这一点。我完全理解位掩码。这个例子是不是错了? 函数 该系统变量是一个八个字符的字符串,其中
我试图从一个二进制文件中取出四个字节,并将它们转换成一个位掩码,代表数据的零和元数据的 1。 我假设我需要通过将它们组合在一起来将它们转换为 int,然后通过移位来确定是否设置了位位置。 我无法弄清楚
这是我的合作伙伴想出的代码,但出于某种原因,我无法联系到他,问他应该如何工作。我现在已经经历了很多次,但似乎无法得到我应该得到的答案。 /** * bitMask - Generate a mask
[旗帜] public enum ShowProductOn : short { HomePage = 1, SalesPage = 2, NewsLetter = 4 };
BufferedImage 类实现 Transparency,它具有三个值: OPAQUE表示不透明。 TRANSLUCENT 表示每个像素的 Alpha 值都在 0 到 1 之间。 BITMASK表
我对这个任务有疑问。 http://www.spoj.com/problems/LINEUP/看起来很简单,但我的解决方案失败了。我得到错误的结果。任何人都可以帮忙弄清楚吗?非常感谢您的帮助。 :-)
我希望能够在 Swift 中正确读取 NSUnderlineStyle 的值。 它比看起来更复杂。 首先,快速回顾一下。 NSUnderlineStyle 是具有以下值的枚举: NSUnderline
我试图避免英雄和硬币之间的碰撞,但不是英雄和草地之间的碰撞。一旦我将碰撞位掩码应用于 Hero,我的 Hero 就会穿过所有东西。我希望它穿过硬币而不是穿过草地。这是代码,有什么想法吗? let HE
所以我决定创建一个控制台类来替代 std::cout console = GetStdHandle(STD_OUTPUT_HANDLE); this->current_color =
我正在研究基于位板的国际象棋引擎,其中一项大量执行的操作是设置/清除无符号 64 位整数中的位。由于我不太了解哪些代码可以在某些处理器上“更快”地运行,因此我无法完全理解这一点。 设置和清除位是一个非
我正在尝试使用 numpy 将几个掩码( bool 数组)转换为一个位掩码,虽然理论上可行,但我觉得我做了太多操作。 例如创建我使用的位掩码: import numpy as np flags = [
例子 self.accessibilityTraits |= UIAccessibilityTraitAdjustable; 添加了 UIAccessibilityTraitAdjustable 选项
我开始使用 ini_get_all 函数来检索共享主机服务器上的所有配置选项。最后我得到了这个数组 block : [allow_call_time_pass_reference] => Array
目前我将一组项目的组合存储为单个整数(位掩码值),如下例所示: 示例: 1 - Orange 2 - Banana 4 - Cherry 8 - Apple 然后如果用户选择Orange (1) 和A
我正在使用 Python 编程并使用 SQLAlchemy 来存储营业时间。 营业时间由三部分组成: 星期几以二进制形式存储为位掩码 营业时间, 企业关闭的时间。 位掩码是这样工作的。有 7 个数字,
我对一种“扩展位”的快速方法很感兴趣,它可以定义如下: 设 B 是一个有 n 位的二进制数,即 B\in {0,1}^n 设P为B中所有1/true位的位置,即1 A 给定 B,使得 Ap[j] ==
我使用嵌入式东西 (PIC),在我见过的所有 C 代码中,如果函数采用多个标志或少量枚举值,它是作为手工制作的 int 位掩码完成的,就像这样: /* first flag */ #define M
所以,最近开始学习iOS开发和Objective-C,主要是利用斯坦福在iTunes U上的免费类(class)。 我最终偶然发现了位掩码,这是 iOS API 中广泛使用但我不是很熟悉的东西。我已经
我想将不同长度的二维数组存储为 AwkwardArray,将它们存储为 Parquet,然后再次访问它们。 问题是,从 Parquet 加载后,格式是 BitMaskedArray并且访问性能有点慢。
我是一名优秀的程序员,十分优秀!