- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
嗨,我有两组数据,取自两个单独的导入文件,它们都被导入到 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/
我是一名优秀的程序员,十分优秀!