gpt4 book ai didi

python - 使用掩码移动知道新坐标的 3D 数组的值

转载 作者:太空狗 更新时间:2023-10-30 00:02:44 27 4
gpt4 key购买 nike

我想扩展一个我已经在 Stackoverflow 上讨论过的问题.它正在处理 2D numpy 数组,我想对 3 维数组做同样的事情。

我想将二维数组的元素“移动”到存储在另外 2 个数组中的新坐标。我希望将其自动化,因为实际上我的数组很大 (400x200x100)。有些值不会找到他的坐标,也不会被使用,其中一些坐标被屏蔽了,我在下面的示例中使用值 0 表明了这一点。如果坐标被屏蔽,我想要重新洗牌的数组中的元素将不会被使用。

import numpy as np

#My new coordinates in X and Y directions

mx = np.array([[[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.]],

[[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.],
[ 1., 2., 3., 4., 0.]]])

my = np.array([[[ 0., 2., 2., 2., 2.],
[ 0., 3., 3., 3., 3.],
[ 0., 4., 4., 4., 4.],
[ 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0.]],

[[ 0., 2., 2., 2., 2.],
[ 0., 3., 3., 3., 3.],
[ 0., 4., 4., 4., 4.],
[ 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0.]]])


IRtest = np.array([[[-0.07383495, -0.08606554, -0.08480594, -0.08099556, -0.08218414],
[-0.07866761, -0.08373 , -0.08253587, -0.08106102, -0.08220205],
[-0.07727436, -0.08271511, -0.0807254 , -0.07832416, -0.08021686],
[-0.07612349, -0.08190446, -0.07996929, -0.07842754, -0.08024891],
[-0.07488144, -0.08150557, -0.08038229, -0.07895656, -0.07997815]],

[[-0.07383495, -0.08606554, -0.08480594, -0.08099556, -0.08218414],
[-0.07866761, -0.08373 , -0.08253587, -0.08106102, -0.08220205],
[-0.07727436, -0.08271511, -0.0807254 , -0.07832416, -0.08021686],
[-0.07612349, -0.08190446, -0.07996929, -0.07842754, -0.08024891],
[-0.07488144, -0.08150557, -0.08038229, -0.07895656, -0.07997815]]])

所以预期的数组看起来像:

array_expected = np.array([[[-0.08271511, -0.0807254 , -0.07832416, -0.08021686, 0],
[-0.08190446, -0.07996929, -0.07842754, -0.08024891, 0],
[-0.08150557, -0.08038229, -0.07895656, -0.07997815, 0],
[0, 0, 0, 0, 0],
[0, 0, 0, 0, 0]],

[[-0.08271511, -0.0807254 , -0.07832416, -0.08021686, 0],
[-0.08190446, -0.07996929, -0.07842754, -0.08024891, 0],
[-0.08150557, -0.08038229, -0.07895656, -0.07997815, 0],
[0, 0, 0, 0, 0],
[0, 0, 0, 0, 0]]])

我尝试使用我在上一篇文章中获得的部分代码。

b = np.zeros_like(IRtest)

for i in range(IRtest.shape[1]):
for j in range(IRtest.shape[2]):
for k in range(IRtest.shape[0]):
b[k, j, i] = IRtest[k,my[k,j,i],mx[k,j,i]]*(mx[k,j,i]!=-1)*(my[k,j,i]!=-1)

b

但是结果和我预想的不一样:

  array([[[-0.08606554, -0.0807254 , -0.07832416, -0.08021686, -0.07727436],
[-0.08606554, -0.07996929, -0.07842754, -0.08024891, -0.07612349],
[-0.08606554, -0.08038229, -0.07895656, -0.07997815, -0.07488144],
[-0.08606554, -0.08480594, -0.08099556, -0.08218414, -0.07383495],
[-0.08606554, -0.08480594, -0.08099556, -0.08218414, -0.07383495]],

[[-0.08606554, -0.0807254 , -0.07832416, -0.08021686, -0.07727436],
[-0.08606554, -0.07996929, -0.07842754, -0.08024891, -0.07612349],
[-0.08606554, -0.08038229, -0.07895656, -0.07997815, -0.07488144],
[-0.08606554, -0.08480594, -0.08099556, -0.08218414, -0.07383495],
[-0.08606554, -0.08480594, -0.08099556, -0.08218414, -0.07383495]]])

最佳答案

你的 map 矩阵是错误的,为了得到你想要的结果,它们需要像这样(因为,当你将值放入 b 时,你正在检查 m[k, j, i] != -1 并且你想要最后一列为 0,而不是第一列)

mx = np.array([[[ 1.,  2.,  3.,  4.,  -1.],
[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.]],

[[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.],
[ 1., 2., 3., 4., -1.]]])

my = np.array([[[ 2., 2., 2., 2., -1.],
[ 3., 3., 3., 3., -1.],
[ 4., 4., 4., 4., -1.],
[ -1., -1., -1., -1., -1.],
[ -1., -1., -1., -1., -1.]],

[[ 2., 2., 2., 2., -1.],
[ 3., 3., 3., 3., -1.],
[ 4., 4., 4., 4., -1.],
[ -1., -1., -1., -1., -1.],
[ -1., -1., -1., -1., -1.]]])

同样在你的循环中,最好在第一个和第二个循环中切换维度,这样它们就变成了

for i in range(IRtest.shape[2]):
for j in range(IRtest.shape[1]):
for k in range(IRtest.shape[0]):

这对于您在此处给出的情况无关紧要,因为矩阵是方阵,但您提到的真正问题是矩阵不是方阵,因此它成为一个问题。

关于python - 使用掩码移动知道新坐标的 3D 数组的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27101456/

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