发生的是循环正在迭代并填充数组的元素,但“元素方面”——即它正在正确计算第一个元素,然后再次循环并用第二个元素填充第一个元素……因此最终,我有一个2d数组/矩阵,其中填充的值应该只在矩阵的最后一个元素中。如何使其在第一个元素被填充后,for循环继续移动到下一个元素和下一个值
以下是我尝试过的:
sim_matrix=np.zeros((3,3), dtype=float)
for i in range(0,3):
for j in range(0,3):
for k in range(0,3):
for l in range(0,3):
sim_matrix[i][j]=node_list_bsc[0][k]['bsc mean value']-node_list_bsc[1][l]['bsc mean value']
#node_list_bsc[x][y]['bsc mean value'] are float values - they are stored in a list of dictionaries,
#hence the double indexing
这使得:
array([[1.14488261e-08, 1.14488261e-08, 1.14488261e-08],
[1.14488261e-08, 1.14488261e-08, 1.14488261e-08],
[1.14488261e-08, 1.14488261e-08, 1.14488261e-08]])
但它应该给出:
[[-5.131371757023141e-10, -7.509188731093747e-08, 7.67647989217221e-07],
[8.933230795306053e-08, 1.475355781782538e-08, 8.574934343459839e-07],
[-7.567123003427902e-07, -8.312910504780254e-07, 1.144882605013307e-08]]
如你所见,它只填充了最后一个元素。我在这些嵌套的中心运行print命令,查看它是如何填充的,如下所示:(示例)
[[-5.13137176e-10 0.00000000e+00 0.00000000e+00]
[ 0.00000000e+00 0.00000000e+00 0.00000000e+00]
[ 0.00000000e+00 0.00000000e+00 0.00000000e+00]]
[[-7.50918873e-08 0.00000000e+00 0.00000000e+00]
[ 0.00000000e+00 0.00000000e+00 0.00000000e+00]
[ 0.00000000e+00 0.00000000e+00 0.00000000e+00]]...
即,第一个元素是正确的,但随后被第二个元素替换。这在代码中可能已经很明显了,但我认为它仍然有助于说明。 我还尝试了while循环和if-else语句,例如:
#pseudo code following:
for i in range(0,3):
for j in range(0,3):
for k in range(0,3):
for l in range(0,3):
if sim_matrix[i][j]==0.0:
sim_matrix[i][j]=node_list_bsc[0][k]['bsc mean value']-node_list_bsc[1][l]['bsc mean value']
else: continue
感觉很接近,但我就是不太明白我哪里出了问题
据我所知,在2D阵列的每个位置都会得到相同的数字。首先,在不了解“节点列表”的情况下,很难提出任何建议。但是,要将值指定给二维数组,只需要两个循环。您的代码可以写成 模拟矩阵=np.零((3,3),数据类型=浮点)
如果不起作用,请让我知道并提供有关节点列表bsc的更多信息
相关问题 更多 >
编程相关推荐