我需要创建一个长度为n的NumPy数组,其中每个元素都是v。
还有什么比:
a = empty(n)
for i in range(n):
a[i] = v
我知道0和1适用于v = 0,1。我可以用v * ones(n),但当v为None时行不通,也会慢得多。
我需要创建一个长度为n的NumPy数组,其中每个元素都是v。
还有什么比:
a = empty(n)
for i in range(n):
a[i] = v
我知道0和1适用于v = 0,1。我可以用v * ones(n),但当v为None时行不通,也会慢得多。
当前回答
没有numpy
>>>[2]*3
[2, 2, 2]
其他回答
没有numpy
>>>[2]*3
[2, 2, 2]
我相信填充是最快的方法。
a = np.empty(10)
a.fill(7)
您还应该始终避免像您在示例中所做的那样进行迭代。简单的A [:] = v将完成使用numpy广播所做的迭代。
我们也可以写成
v=7
n=5
a=np.linspace(v,v,n)
我有np。数组(n * [value]),但显然,对于足够大的n,这比所有其他建议都要慢。就可读性和速度而言,最好的是
np.full(n, 3.14)
这里是与perfplot(我的一个宠物项目)的完整比较。
两个空的替代品仍然是最快的(NumPy 1.12.1)。完全赶上大数组。
代码生成的情节:
import numpy as np
import perfplot
def empty_fill(n):
a = np.empty(n)
a.fill(3.14)
return a
def empty_colon(n):
a = np.empty(n)
a[:] = 3.14
return a
def ones_times(n):
return 3.14 * np.ones(n)
def repeat(n):
return np.repeat(3.14, (n))
def tile(n):
return np.repeat(3.14, [n])
def full(n):
return np.full((n), 3.14)
def list_to_array(n):
return np.array(n * [3.14])
perfplot.show(
setup=lambda n: n,
kernels=[empty_fill, empty_colon, ones_times, repeat, tile, full, list_to_array],
n_range=[2 ** k for k in range(27)],
xlabel="len(a)",
logx=True,
logy=True,
)
您可以使用numpy。瓷砖,例如:
v = 7
rows = 3
cols = 5
a = numpy.tile(v, (rows,cols))
a
Out[1]:
array([[7, 7, 7, 7, 7],
[7, 7, 7, 7, 7],
[7, 7, 7, 7, 7]])
尽管tile是为了“平铺”一个数组(而不是在这种情况下的标量),它将完成工作,创建任何大小和维度的预填充数组。