我有一个带坐标的 3d 网格
x = linspace(0, Lx, Nx)
y = linspace(0, Ly, Ny)
z = linspace(0, Lz, Nz)
我需要在某个位置(x0,y0,z0)的某个半径R内索引点(即x [i],y [j],z [k])。N_i 可以很大。我可以做一个简单的循环来找到我需要的东西
points=[]
i0,j0,k0 = floor( (x0,y0,z0)/grid_spacing )
Nr = (i0,j0,k0)/grid_spacing + 2
for i in range(i0-Nr, i0+Nr):
for j in range(j0-Nr, j0+Nr):
for k in range(k0-Nr, k0+Nr):
if norm(array([i,j,k])*grid_spacing - (x0,y0,k0)) < cutoff:
points.append((i,j,k))
但这很慢。有没有更自然/更快的方法来使用 numpy 进行这种类型的操作?