gpt4 book ai didi

python - python中2个列表的3D插值

转载 作者:太空宇宙 更新时间:2023-11-03 17:50:49 25 4
gpt4 key购买 nike

嗨,我有两组数据,取自两个单独的导入文件,它们都被导入到 python 中,并被放置在两个单独的列表中,如下所示:

列表 1 的形式为:

(node, x coordinate, y coordinate, z coordinate)
example list 1: [[1,0,0,0],[2,1,0,0],[3,0,1,0],[4,1,1,0],[5,0,0,1],[6,1,0,1],[7,0,1,1],[8,1,1,1]]

列表 2 的格式为:

(x coordinate, y coordinate, z coordinate, temperature)
example list 2: [[0,0,0,100],[1,0,0,90],[0,1,0,85],[1,1,0,110],[0,0,1,115],[1,0,1,118],[0,1,1,100],[1,1,11,96]]

从这两个列表中,我需要使用坐标创建第三个列表,其中包含节点值及其相应的温度。如果所有 x y 和 z 坐标都匹配,则此任务是一个简单的字典函数,但对于我正在使用的数据,情况并非总是如此。

例如,如果在列表 1 中我在列表末尾添加一个新条目,节点号为 9;

new entry at end of list 1 [9, 0.5, 0.9, 0.25]

现在我发现自己的节点号没有对应的温度。此时,需要对列表 2 执行插值函数,以给出与该节点相关的温度。通过基本的 3D 插值计算,我计算出该温度将为 97.9,因此我的最终输出列表如下所示:

输出列表:

(node, temperature)
Output list: [[1,100],[2,90],[3,85],[4,110],[5,115],[6,118],[7,100],[8,96],[9,97.9]]

我对Python相当陌生,所以正在努力寻找这个插值问题的解决方案,我已经研究如何做到这一点已经好几个星期了,但仍然无法找到解决方案。

任何帮助将非常非常感激,

谢谢

最佳答案

scipy 中有相当多的插值例程,但在二维以上,大多数只提供线性和最近邻插值 - 这可能不足以满足您的使用。

所有插值例程都列在 interplation 上scipy 文档区域的页面。您可以立即忽略多变量、1D 和 2D 样条部分 - 您需要 multivariate部分。

这里有 9 个函数,分为结构化数据和非结构化数据:

Unstructured data:

griddata(points, values, xi[, method, ...]) Interpolate unstructured D-dimensional data.

LinearNDInterpolator(points, values[, ...]) Piecewise linear interpolant in N dimensions.

NearestNDInterpolator(points, values) Nearest-neighbour interpolation in N dimensions.

CloughTocher2DInterpolator(points, values[, tol]) Piecewise cubic, C1 smooth, curvature-minimizing interpolant in 2D.

Rbf(*args) A class for radial basis function approximation/interpolation of n-dimensional scattered data.

interp2d(x, y, z[, kind, copy, ...]) Interpolate over a 2-D grid. For >

data on a grid:

interpn(points, values, xi[, method, ...]) Multidimensional interpolation on regular grids.

RegularGridInterpolator(points, values[, ...]) Interpolation on a regular grid in arbitrary dimensions

RectBivariateSpline(x, y, z[, bbox, kx, ky, s]) Bivariate spline approximation over a rectangular mesh.

另请参阅部分中添加一个附加内容,尽管我们会忽略它。

您应该阅读它们各自的工作原理,这可能会帮助您更好地理解。

这些函数的工作方式是,您向它们传递数据,即 x,y,z 坐标以及这些点的相应值,然后它们返回一个函数,您可以通过该函数获取任意位置的一个点。

我会推荐Rbf不过,据我所知,它是唯一的 nD 选项,不会限制您使用线性或最近邻插值。

例如,您有两个列表:

node_locations = [(node, x_coord, y_coord, z_coord), ...]
temp_data = [(x0, y0, z0, temp0), (x1, y1, z1, temp1), ...]

xs, ys, zs, temps = zip(*teemp_data) # This will unpack your data into columns, rather than rows.

from scipy.interpolate import Rbf
rbfi = Rbf(xs, ys, zs, temps)

# I don't know how you want your output data, so i'm just dumping it in a dictionary.
node_data = {}
for node, x, y, z in node_locations:
node_data[node] = rbfi(x, y, z)

尝试类似的事情。

关于python - python中2个列表的3D插值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29123463/

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