我正在尝试在 python27 中重写 matlab 代码。有一个matlab行如下:
vector_C = vector_A > vector_B;
如果我尝试使用 numpy 在 python 中编写它,它将是相同的,但结果将是一个布尔数组而不是二进制文件。我希望结果是二进制文件。有没有办法让它返回二进制文件或者我应该每次都手动转换?有没有快速转换的方法?我是 python 新手。谢谢。
即使vector_C
可能有dtype=bool
,您仍然可以进行如下操作:
In [1]: vector_A = scipy.randn(4)
In [2]: vector_B = scipy.zeros(4)
In [3]: vector_A
Out[3]: array([ 0.12515902, -0.53244222, -0.67717936, -0.74164708])
In [4]: vector_B
Out[4]: array([ 0., 0., 0., 0.])
In [5]: vector_C = vector_A > vector_B
In [6]: vector_C
Out[6]: array([ True, False, False, False], dtype=bool)
In [7]: vector_C.sum()
Out[7]: 1
In [8]: vector_C.mean()
Out[8]: 0.25
In [9]: 3 - vector_C
Out[9]: array([2, 3, 3, 3])
所以,简而言之,你可能不需要做任何额外的事情。
但是,如果您必须进行转换,您可以使用astype
:
In [10]: vector_C.astype(int)
Out[10]: array([1, 0, 0, 0])
In [11]: vector_C.astype(float)
Out[11]: array([ 1., 0., 0., 0.])
您可以强制 numpy 将元素存储为整数。它将 0 视为假,将 1 视为真。
import numpy
vector_C = numpy.array( vector_A > vector_B, dtype=int) ;