gpt4 book ai didi

python - Numpy 矢量化以提高性能

转载 作者:行者123 更新时间:2023-12-01 06:38:15 24 4
gpt4 key购买 nike

我目前正在尝试对我的代码进行矢量化以减少其处理时间,但在尝试时发生了广播错误。

我有两个向量,形状为 (200,) 的 TDOA_values 和形状为 (257,) 的 __Frequency_bins__

现在我想使用这些向量的元素来填充我的“空白”矩阵temp_gcc_results其定义如下: temp_gcc_results = np.zeros((len(TDOA_values), len(__Frequency_bins__))) 该数组的形状为 (200, 257)。

现在,我尝试通过为 __Frequency_bins__ 的每个元素计算 TDOA_values 的每个元素来填充 temp_gcc_results 的每个单元格:

temp_gcc_results[:, :] = (Rxx12/abs(Rxx12) * np.exp(-2j * np.pi * TDOA_values * __frequency_bins__)).real

不幸的是,执行此代码会导致以下错误:

operands could not be broadcast together with shapes (200,) (257,) 

我现在的问题是我不明白为什么Python尝试广播而不是用公式中的值替换零。

感谢您的帮助!

最佳答案

您需要使用np.newaxis:

# array(m x n) = array(m x 1) * array(1 x n)

import numpy as np
Rxx12 = 1 # TODO, not specified in the question
TDOA_values = np.random.random(200)
__frequency_bins__ = np.random.random(257)
temp_gcc_results = np.zeros((len(TDOA_values), len(__frequency_bins__)))
temp_gcc_results[:, :] = (Rxx12/abs(Rxx12) * np.exp(-2j * np.pi * TDOA_values[:, np.newaxis] * __frequency_bins__[np.newaxis, :])).real

# You actually don"t need to initialize *temp_gcc_results* in your case
temp_gcc_results = (Rxx12/abs(Rxx12) * np.exp(-2j * np.pi * TDOA_values[:, np.newaxis] * __frequency_bins__[np.newaxis, :])).real

您的错误发生在这里,在两个形状不匹配的数组相乘时:

TDOA_values * __frequency_bins__

不在将结果分配给:

temp_gcc_results[:, :] 

关于python - Numpy 矢量化以提高性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59566618/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com