2

我需要一个等效于interp2 MATLAB 函数的 Python。我试图让这个MATLAB 示例在 Python 中工作,但我做不到。

import numpy as np

from scipy.interpolate import interp2d
from scipy.interpolate import RectBivariateSpline

service = np.array(range(10, 31, 10))
years = np.array(range(1950, 1991, 10))

wage = np.array([[150.6970,199.5920,187.6250],
    [179.3230, 195.0720, 250.2870],
    [203.2120, 179.0920, 322.7670],
    [226.5050, 153.7060, 426.7300],
    [249.6330, 120.2810, 598.2430]])

ip = RectBivariateSpline(years, service, wage)

print(ip(15, 1975))

但是我得到了这个我无法解决的错误(在 RectBivariateSpline 中):

    Traceback (most recent call last):
  File "/Users/andrea/Documents/workspace/PythonProjects/pyArmBot/src/foo.py", line 15, in <module>
    ip = RectBivariateSpline(years, service, wage)
  File "/Library/Python/2.7/site-packages/scipy-0.10.1-py2.7-macosx-10.7-intel.egg/scipy/interpolate/fitpack2.py", line 728, in __init__
    kx,ky,s)
4

3 回答 3

1

我相信您需要通过使用以下行而不是您的打印行来调用 ip 来返回一个值。

print(ip.ev(15, 1975))

更新:

很容易调整。并盯着我的脸。您可以设置 kx 和 ky 的值,它们是二元样条的度数请参阅此处的文档

无论如何,只需将行调整为:

ip = RectBivariateSpline(years, service, wage, kx=2, ky=2)

如果你不想,你不需要调整 kx。如果您将 kx 保留为 3,我怀疑它会大大改变插值。

于 2012-07-16T12:34:05.503 回答
0

blueSurfer,我认为您设置插值的方式将获得正确的结果,ip(1975, 15)而不是相反。

于 2015-05-18T10:51:07.100 回答
0

我遇到了同样的问题,并发现scipy.ndimage.map_coordinates它与Vq = interp2(V,Xq,Yq). 请阅读这些命令的文档以找出适合您情况的解决方案。

试试这个 Matlab 的Vq = interp2(V,Xq,Yq)

Vq = scipy.ndimage.map_coordinates(V, [Xq.ravel(), Yq.ravel()], order=3, mode='nearest').reshape(V.shape)
于 2017-05-08T14:30:34.877 回答